对于 CF1107E 中 dp 状态设计的一点想法

news/2024/10/14 0:27:07

不太想发到洛谷讨论区,就往这里放了。

我觉得现有的题解都没说明白为什么本题的状态和转移能覆盖所有情况,并且感觉也非常不自然,没见过的话感觉挺难发现这么一个东西。

然而这个 dp 其实是可以自然地推导出来的。

首先发现这个过程非常难以描述,主要原因在于很难刻画一个局面。然而,如果知道一个局面是什么样的,转移是简单的。

因此我们考虑 时光倒流,直接考虑最后一次操作,这时的局面非常简单:一定是删掉全部的数。

然后考虑这次操作在原序列上的表现:选定若干个字符相等的位置 \(s_1,s_2,\dots,s_k\),分割出来若干段形如 \((s_i,s_{i+1})\) 这样的区间,因为我们是倒着操作的,所以这些分割出来的区间不会再有交集,直接做下去就好了。

为了转移,我们定义辅助数组 \(g(l,r,k)\):表示我们选了 \(k\) 个位置留作最后操作的最大价值。转移并不困难,然后再得到 \(f(l,r)\) 即可。

发现这个东西其实和 [THUSC 2016] 成绩单 描述的 dp 是很类似的。

回过头来看一看我们干了一件什么事,因为删掉 \((s_i,s_{i+1})\) 这样的区间的顺序并不重要,我们可以这样从右往左考虑这个过程:

  • 保留一个位置,并删掉和前一个保留的位置之间的区间。要求保留的位置上的字符相同。

这个 保留的位置 就是 luogu 题解里面的 \(f(l,r,k)\)\(k\) 的含义,当然也有一点不同:允许过程中把这个 \(k\) 清空。

直接正着想的话可能也能感受到这个过程,但毕竟不怎么自然啊。

所以这种过程性较强的题目,从最终局面出发始终可以作为一种选择。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/26867.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

解决vscode连接远程服务器出现Bad owner or permissions on C:\\Users\\Administrator/.ssh/config 过程试图写入的管道不存在。

1.找到.ssh文件夹。它通常位于C:\Users2.右键单击.ssh文件夹,然后单击“属性”,选择“安全”3.单击“高级”。 单击“禁用继承”,单击“确定”。 将出现警告弹出窗口。单击“从此对象中删除所有继承的权限”。 4.此时所有用户都将被删除。添加所有者。在同一窗口中,单击“编…

TCP的三次握手过程

TCP 是面向连接的、可靠的、基于字节流的传输层通信协议。TCP 是面向连接的协议,所以使用 TCP 前必须先建立连接,而建立连接是通过三次握手来进行的...TCP是面向连接的、可靠的、基于字节流的传输层通信协议。 TCP是面向连接的协议,所以使用 TCP前必须先建立连接,而建立连接…

用 Python 开发一个【GIF表情包制作神器】

用python成为了微信斗图届的高手然后,好多人表示:虽然存了很多表情包但似乎还不是很过瘾因为它不可以自己来定制我们可不可以根据一些表情素材然后自己制作专属表情包呢像这样本来小帅b想自己实现一个表情包制作器后来发现已经有人在 GitHub 分享了 主要功能就是 可以在原有的…

DRM

DRM是Linux目前主流的图形显示框架,相比FB架构,DRM更能适应当前日益更新的显示硬件。 比如FB原生不支持多层合成,不支持VSYNC,不支持DMA-BUF,不支持异步更新,不支持fence机制等等,而这些功能DRM原生都支持。 同时DRM可以统一管理GPU和Display驱动,使得软件架构更为统一…

Clock Switch,芯片时钟切换的毛刺是什么,如何消除

背景 芯片运行过程中需要时钟切换时,要考虑到是否会产生glitch,小小的glitch有可能导致电路运行的错误。所以时钟切换时需要特别的处理。 直接使用MUX进行时钟切换或者采用如下电路结构进行时钟切换:assign outclock = (clk1 & select) | (~select & clk0);或 assig…

【计算机网络】通过ensp实验分析二三层数据包转发过程

一、实验准备 需要提前安装好wireshark、virtalbox、WinPcap和模拟工具ensp,具体的安装过程可以自行百度~ 特别提醒一点就是virtalbox和ensp的兼容性问题,我安装的是ensp1.3.00.100版本,该版本不支持virtalbox官网的6和7版本,我这边退回到5版本才正常运行起来。二、网络拓扑…

Redis持久化、主从与哨兵架构详解

参考 图灵课堂 https://zhuanlan.zhihu.com/p/443951927 https://blog.csdn.net/weixin_37548768/article/details/124538778?spm=1001.2014.3001.5502 https://www.runoob.com/redis/redis-transactions.htmlredis支持持久化到磁盘,这样可用进一步保证数据的完整性。 redis持…

异或

这道题目的思路比较好 由于\(1\)到\(n\)的路径很多,我们猜想,任意选一条路径可以通过某种异或运算来得到最优解 证明:假设我们选出的路径不是最优路径,那么对于另一条最优路径,一定可以通过我们选出的路径异或上若干个简单环来达到。举个例子说明假设我们选出的是直线段\(…