news 2026/6/24 1:25:41

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/6/23 7:09:09

rt-linux下的“硬实时”的hrtimer通知机制

一、背景 之前的一些rt-linux的博客已经讲到,由于rt-linux下注册的hrtimer的回调默认都并非在硬中断里直接执行,而是被放到的软中断里去执行,这会导致一些实时性的问题,甚至一些系统基础的操作如常见的一些用户态定时睡眠的一些操作在rt-linux下变得有些波动。另外,有些抓…

作者头像 李华
网站建设 2026/6/23 21:47:31

60、C 编程综合知识解析

C# 编程综合知识解析 1. 并发类与集合 在 C# 编程中, System.Collections.Concurrent 命名空间提供了一系列并发类,这些类在多线程环境下能高效地处理数据集合。主要的并发类包括: - ConcurrentQueue<T> :实现了先进先出(FIFO)的队列,可在多线程环境下安全地…

作者头像 李华
网站建设 2026/6/23 21:45:57

3、矩阵、狄拉克符号与经典及量子计算基础

矩阵、狄拉克符号与经典及量子计算基础 1 方阵相关性质 方阵具有多种重要性质,基于这些性质可定义出在经济学和金融领域有广泛应用的特殊方阵。假设 (A) 是一个 (NN) 的可逆复值方阵,与之相关的矩阵如下: |矩阵类型|符号|分量规则|示例(以 (A = \begin{pmatrix}1 & …

作者头像 李华
网站建设 2026/6/23 23:19:11

6、量子力学原理:自由度、希尔伯特空间与算子

量子力学原理:自由度、希尔伯特空间与算子 1. 自由度:不确定性的基石 量子力学的基础在于自由度。在量子计算机中,经典计算机的单个 1 位(x = {0, 1})在量子力学里被提升为量子二进制自由度。一个比特的两个值 x = {0, 1} 共同构成了二进制自由度 F = {0, 1}。 1.1 多比…

作者头像 李华
网站建设 2026/6/23 22:48:25

使用gitee快速下载国外文件方案

1 使用特殊手段下载到本地----这个速度很快2 使用gitee上传文件到gitee服务器3 使用gitclone同步到需要下载文件的电脑上

作者头像 李华