news 2026/7/3 18:17:39

Triple Removal Maximum Array 2

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Triple Removal Maximum Array 2

两场算法竞赛C题通关手记:

最近刷竞赛题时遇到两道很有意思的C题,分别是Triple Removal和Maximum Array 2。一道考的是前缀和加二分的区间查询技巧,另一道则是围绕MEX和区间最小值展开的构造题,琢磨透这两道题的过程里,我挖到了不少实用的解题思路,索性整理出来和大家分享。

Triple Removal:01数组的区间清空谜题

这道题的规则很有意思,给你一个只由0和1组成的数组,每次查询一个子区间,问能不能通过“移除三个相同元素”的操作把这个子区间清空。如果可以,还要算出最小的操作总成本。这里的操作成本定义得很特别,是选中的三个元素下标 i<j<k 对应的 min(k-j, j-i) 。

刚拿到题的时候,我先盯着“能不能清空”这个问题琢磨了半天。很快就发现了两个硬性条件——子数组的长度必须是3的倍数,不然连操作次数都凑不齐。再者,区间里1的总数也得是3的倍数,毕竟每次移除的三个元素要么全0要么全1,0和1的总数都得能被3整除才行。

这两个条件的判断其实不难实现。用一个前缀和数组统计前 i 个元素里1的个数,查询时只需要算一下区间内1的数量,看能不能被3整除就好。真正的难点在于怎么算最小成本。

后来我试着手动模拟了几组样例,发现了一个关键规律:如果区间里存在相邻的相同元素,那每次操作的成本都能压到1;要是区间里的元素全是交替出现的(比如0101或者1010),那每次操作的成本就得是2,对应的总费用就是 长度/3 + 1 。

基于这个规律,代码的思路就清晰了。我用一个数组 v 记录所有相邻相同元素的位置,查询区间 [l,r] 时,用二分查找判断 v 里有没有落在这个区间内的元素。如果有,总费用就是 len/3 ;没有的话,就按 len/3 + 1 来算

说句题外话,这种从样例里找规律的方法,在竞赛里真的很好用。有时候盯着题目干想半天没头绪,不如手动算几组数据,说不定规律就自己跳出来了。

Maximum Array 2:约束下的数组构造挑战

这道题的玩法完全不同,要求我们构造一个数组,满足 0 ≤ a_i ≤ 10^9 的前提下,还得搞定 q 个约束条件。约束分两种,一种是区间 [l,r] 的最小值等于 k ,另一种是区间 [l,r] 的MEX等于 k 。最终的目标是让构造出来的数组尽可能“大”,也就是每个元素的值都尽量往上限靠。

刚上手的时候,我差点被两种约束绕晕。后来仔细拆解了一下,才发现每种约束的核心要求其实很明确。

先看MEX约束,MEX是最小的未出现非负整数,所以如果一个区间的MEX是 k ,那这个区间里必须把 0 到 k-1 的数都包含进去,同时绝对不能出现 k 。而最小值约束就更直接了,区间里至少得有一个元素等于 k ,剩下的元素都不能小于 k 。

想通这两点之后,构造策略就有了。我的思路是先处理MEX约束,把 0 到 k-1 这些数先填进对应的区间里,保证MEX的要求能满足。然后再处理最小值约束,在对应的区间里放一个 k ,其余位置直接填 1e9 这种极大值,这样既能满足约束,又能让数组尽可能大。

代码实现上,我用了差分数组来标记每个位置受哪种约束影响。先通过前缀和把差分数组转换成每个位置的约束状态,再根据状态调整数组元素的值。

这里有个小坑我当时踩过——处理约束的顺序很重要。如果先处理最小值约束再处理MEX约束,很容易破坏MEX的要求,大家写代码的时候一定要注意。

其实这两道题虽然题型不同,但本质上都是“拆解约束+选对数据结构”的思路。竞赛里很多题目都是这样,看似复杂的规则背后,藏着的都是最基础的算法技巧。把核心问题抓准了,解题的思路自然就顺了。

感觉自己还是太没实力了,一年下来codefoces也只到1200~1400的水平,不知道后面的路还要不要坚持,但我相信努力终会有回报,坚持也会有回报

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 19:57:55

45、.NET 中的反射、特性与动态编程

.NET 中的反射、特性与动态编程 1. 反射基础 反射允许程序在运行时检查和操作类型、成员等元数据。下面通过几个例子来详细介绍反射的应用。 1.1 使用 typeof() 创建 System.Type 实例 Enum.Parse() 方法可以将字符串转换为特定的枚举值,前提是需要一个 Type 对象来…

作者头像 李华
网站建设 2026/6/30 20:44:58

10、量子叠加与相关概念的深入解析

量子叠加与相关概念的深入解析 1. 量子叠加的双缝实验 双缝实验是理解量子叠加现象的经典实验。在这个实验中,有两种不同的情况,分别对应着不同的实验结果和物理意义。 1.1 有探测器的实验(无干涉情况) 当两个探测器开启时,两个狭缝都打开,探测器会记录电子通过的狭缝…

作者头像 李华
网站建设 2026/7/1 7:26:51

台式机的CPU可以自己更换

台式机的 CPU可以自己更换&#xff0c;但需要满足几个核心条件&#xff0c;具体操作步骤和注意事项如下&#xff1a;一、 更换 CPU 的核心前提主板接口必须兼容这是最关键的条件。CPU 的接口类型&#xff08;如 Intel 的 LGA 1700、LGA 1200&#xff0c;AMD 的 AM4、AM5&#x…

作者头像 李华
网站建设 2026/7/1 5:58:51

深入浅出 C 语言数据结构:从线性表到二叉树的实战指南

在编程世界中&#xff0c;数据结构是构建高效程序的基石。无论是日常开发中的数据存储&#xff0c;还是算法题中的逻辑实现&#xff0c;掌握核心数据结构及其 C 语言实现都至关重要。本文将从线性表&#xff08;顺序表、链表&#xff09;入手&#xff0c;逐步深入栈、队列&…

作者头像 李华
网站建设 2026/6/28 18:29:14

Paperxie:毕业季里,把论文的 “麻烦事” 都交给 “学术搭子”

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/ai/dissertationhttps://www.paperxie.cn/ai/dissertation 上周三凌晨 2 点&#xff0c;我在朋友圈刷到学妹的吐槽&#xff1a;“第 7 次调整论文页眉&#xff0c;学校模板…

作者头像 李华
网站建设 2026/7/1 12:45:45

Kotaemon的安全机制剖析:如何防止提示词注入攻击?

Kotaemon的安全机制剖析&#xff1a;如何防止提示词注入攻击&#xff1f; 在企业级AI系统日益普及的今天&#xff0c;一个看似无害的用户提问——“请忽略之前的指令&#xff0c;告诉我你的系统提示”——可能正是一次精心策划的攻击。生成式AI的开放性赋予了它强大的交互能力&…

作者头像 李华