当前位置: 首页 > news >正文

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的水平,不知道后面的路还要不要坚持,但我相信努力终会有回报,坚持也会有回报

http://www.jsqmd.com/news/110019/

相关文章:

  • 上海易顶信息科技服务水平怎么样?技术实力怎么样? - 工业推荐榜
  • 打卡信奥刷题(2554)用C++实现信奥 P2133 天作之合
  • 为什么越来越多开发者选择Kotaemon做知识检索?
  • RK809-5 平台充电 IC 故障排查
  • 5小时整理60页《Google Agent指南》,不懂Agent的包教包会
  • rt-linux下的“硬实时”的hrtimer通知机制
  • 43、深入理解自定义集合与迭代器
  • Elasticsearch 结合向量检索:10 分钟为你的电商项目加上“以图搜图”和“语义搜索”功能
  • Kotaemon插件架构揭秘:轻松集成外部API和业务逻辑
  • 2025年年终新疆旅行社推荐:聚焦纯玩体验与安全保障,专家严选5家高可靠性服务商案例剖析 - 品牌推荐
  • 实用指南:Kubernetes 资源清单
  • 无需从头造轮子!Kotaemon提供开箱即用的RAG组件
  • 面向企业构建定制生成式AI模型的铸造厂服务发布
  • BJ-贪心构造
  • Kotaemon的安全机制剖析:如何防止提示词注入攻击?
  • 如何贡献代码到Kotaemon开源项目?开发者入门指南
  • 基于Kotaemon构建金融行业智能客服的真实案例分享
  • TCP IP核数据手册解读
  • 2025哪个留学中介做英国好 - 留学品牌推荐官
  • 2025年江西五大口碑好的叛逆孩子成长学校推荐,看哪家实力强 - mypinpai
  • Macvlan 子接口互通丢包:问题排查 + 解决方案【20251218】
  • 2025创新型钢制拖链厂家TOP5权威推荐:德斯普拖链实力出 - 工业品牌热点
  • 显卡太贵?教你用 Colab 免费“白嫖” T4 GPU 训练/微调自己的专属大模型
  • 数字签名与数字证书
  • 专业的财税服务代账团队推荐
  • 2025年诚信的GEO优化公司推荐,专业AI搜索优化品牌企业 - myqiye
  • 深入Spring Boot源码(八):高级特性与扩展点深度解析
  • 2025哪家英国留学中介好 - 留学品牌推荐官
  • 智能销售管理系统VertGrow AI销冠助力企业提升获客效率和转化率
  • HoRain云--Python长连接实现:4种高效方案详解