CF1842C Tenzing and Balls 题解
一眼 dp。
状态:令 \(dp_i\) 表示前 \(i\) 个数进行若干次操作能删除的最多的数的个数。
转移方程:
\[dp_i = \max(dp_{i-1},dp_{j-1}+i-j+1)
\]
其中 \(j\) 满足 \(1 \le j < i\) 且 \(a_i = a_j\)。
不过这样朴素地转移,时间复杂度是 \(O(n^2)\) 的,无法接受。
我们观察到,对于上述转移方程,未知量是 \(dp_{j-1}-j+1\)。
于是我们考虑令 \(f_i\) 表示数 \(i\)(注意不是下标 \(i\))对应的满足 \(a_j=i\) 的最大的 \(dp_{j-1}-j+1\)。
这个 \(f_i\) 可以在转移的同时维护,转移方程:
\[f_{a_i}=\max(f_{a_i},f_{i-1}-i+1)
\]
注意这个转移方程中的 \(i\) 就不是数值而是下标了。
最后输出 \(dp_n\) 即可。时间复杂度降至 \(O(n)\)。
代码很好写,就不展示了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】