很犀利的一个状态压缩DP
整理一下吧,昨天比赛一点思路都没有
今天看了下题解,思路才清楚起来
唉,我的DP太水了
3个规则
第1个规则是对于A和B转换成二进制转换
第2个规则是重叠A串的后缀和B串的前缀
第3个规则是如果B串是A串的子串,可以用A去覆盖B
首先是将各个数字转换成二进制串,这里注意反转一下串
我们先满足第三个规则,这个比较简单,仅仅是判断下某个串是否是其他串的子串,是的话,就直接不要了
接着找出任意两个串的彼此前缀和后缀的最长长度,标记一下
接着就开始DP的过程了
按位DP,N=1<<n,某一位有1说明这个串被使用了
递推方程dp[i][j],是指第i个状态用第j个字符串做前缀的最小长度
递推方程不难构造,不作解释了
另外构造字符串并不难,不说了
本文深入探讨状态压缩DP在解决串匹配问题上的应用,通过三个核心规则进行串的转换与匹配,详细解析DP过程与字符串操作技巧。
1761

被折叠的 条评论
为什么被折叠?



