消木块
假设我们按照常规的方程设置的方法,设
这一段木块要么自己被单独消掉,要么与前面颜色相同的木块一起消掉
对于第一种情况,这个操作肯定可以在最开始做而不影响答案,所以有
对于第二种情况,我们可以调整操作顺序,先消掉前面颜色相同的木块和最后这段颜色相同的木块中间的木块(注意这中间的木块也可能有颜色相同的木块,到时候枚举就可以了),然后让最后这段颜色相同的木块和前面颜色相同的木块拼在一起,考虑怎么消掉剩下的木块
然后到这个时候,你就会发现推不走了,因为没有一个状态能够表示剩下的木块了(注意到了这一步不能单纯地认为我们下一步就是消掉最后这段颜色相同的木块和前面颜色相同的木块拼在一起的这一段更长的颜色相同的木块,因为完全有可能再从前面的木块中消掉一些木块,继续增加这段颜色相同木块的长度),所以要调整状态
可能我们会想到一个状态
但是这样做的问题就是仍然没有办法表示剩下的木块,注意
但是我们可以发现,按照上面说的第二种情况(木块状态见下)
我们先删除掉
update 2024.8.29
所以区间DP也可以考虑两端点在最终状态的情况然后去涉及状态
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构