消木块

假设我们按照常规的方程设置的方法,设f[i][j]表示消除区间[i,j]所有木块的最大得分,我们考虑最后一段颜色相同的木块

这一段木块要么自己被单独消掉,要么与前面颜色相同的木块一起消掉

对于第一种情况,这个操作肯定可以在最开始做而不影响答案,所以有f[i][j]=f[i][k]+value,其中[k+1,j]的颜色相同

对于第二种情况,我们可以调整操作顺序,先消掉前面颜色相同的木块和最后这段颜色相同的木块中间的木块(注意这中间的木块也可能有颜色相同的木块,到时候枚举就可以了),然后让最后这段颜色相同的木块和前面颜色相同的木块拼在一起,考虑怎么消掉剩下的木块

然后到这个时候,你就会发现推不走了,因为没有一个状态能够表示剩下的木块了(注意到了这一步不能单纯地认为我们下一步就是消掉最后这段颜色相同的木块和前面颜色相同的木块拼在一起的这一段更长的颜色相同的木块,因为完全有可能再从前面的木块中消掉一些木块,继续增加这段颜色相同木块的长度),所以要调整状态

可能我们会想到一个状态f[i][j][k]表示区间[i,j],最后有k个木块颜色相同

但是这样做的问题就是仍然没有办法表示剩下的木块,注意f[i][p][t](其中t表示最后这段颜色相同的木块和前面颜色相同的木块拼在一起的木块总数,p表示前面颜色相同的木块的最前面的木块的前面一个木块,即颜色不同的最后一个木块的位置)是不对的,因为这个状态就是错的,[i,p]这个区间的末尾根本没有t个颜色相同的木块

但是我们可以发现,按照上面说的第二种情况(木块状态见下)

我们先删除掉[q+1,p1]这一段木块,最后让后q和最后这一段颜色相同的木块挨在一起,会发现,此时的状态与[l,q]这一段的状态相比,就是末尾多了一段颜色相同的木块,也就是说,我们现在要解决的子问题是,消除[l,q]这一段木块加上末尾多了若干个与位置q颜色相同的木块,所能获得的最多的分数,于是可以想到如下状态

update 2024.8.29

所以区间DP也可以考虑两端点在最终状态的情况然后去涉及状态

posted @   最爱丁珰  阅读(4)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示