【POJ 3280】 Cheapest Palindrome(动态规划 回文串)
来源:互联网 发布:男装品牌 知乎 编辑:程序博客网 时间:2024/05/21 23:41
题意:现在有一个由n个字符组成的长度为m的字符串,可以对其通过增加字符或者删除字符来使其变成回文字符串,而增加或者删除字符都有一个花费,求解使该字符串变成回文所进行操作的最小花费.
用dp[start][end]表示使字符串ss[being]……ss[end]变成回文字符串所需的最小花费,只需考虑开始位置和结束位置即可.
1> 如果ss[begin]!=ss[end],那么有四种操作可以使其变成回文:
a> 在dp[begin+1][end]处添加或者删除字符ss[begin],所以这两种操作花费为:dp[begin][end]=min{dp[begin+1][end]+add[begin],dp[begin+1][end]+del[begin]}
用cost[begin]表示cost[begin]=min(add[begin],del[begin]),则上述方程可以写成:dp[begin][end]=dp[begin+1]+cost[begin]
b> 在dp[begin][end-1]处添加或者删除字符ss[end],所以这两种操作的花费为:dp[begin][end]=dp[begin][end-1]+cost[end]
2> 如果ss[begin]=ss[end],那么有两种情况构成回文数,即字符串保持不变和删除ss[begin]和ss[end],也就是选择dp[begin][end]与dp[begin+1][end-1]中的最小值.
综上所述:状态转移方程为:
dp[begin][end]=min{dp[begin+1][end]+cost[begin],dp[begin][end-1]+cost[end]} ss[i]!=ss[j]
dp[begin][end]=min{dp[begin][end],dp[begin+1][end-1]} ss[i]=ss[j]
- 【POJ 3280】 Cheapest Palindrome(动态规划 回文串)
- poj 3280 Cheapest Palindrome ---(DP 回文串)
- POJ 3280 Cheapest Palindrome 动态规划法题解
- poj 3280 Cheapest Palindrome(最长回文串变形)
- poj 3280 Cheapest Palindrome(回文字符串dp)
- POJ 3280 Cheapest Palindrome (回文字符串)
- poj 1159 Palindrome -- 回文串,动态规划
- Cheapest Palindrome - 最小代价构造回文 动态规划
- Poj 3280 Cheapest Palindrome
- POJ 3280 Cheapest Palindrome
- poj 3280 Cheapest Palindrome
- POJ 3280 Cheapest Palindrome
- POJ 3280 Cheapest Palindrome
- poj 3280 Cheapest Palindrome
- POJ 3280--Cheapest Palindrome
- POJ 3280 Cheapest Palindrome
- poj 3280 Cheapest Palindrome
- POJ 3280 Cheapest Palindrome
- url传值用request.getparameter显示汉字乱码的解决方法
- apache mina 2
- 在Eclipse中集成Ant编程的配置
- 常用的资源链接
- 三维空间里一个点绕坐标轴旋转
- 【POJ 3280】 Cheapest Palindrome(动态规划 回文串)
- mysql 的DATE_FORMAT() 函数
- C++中非多态类对象的内存映像规则
- ASM - Scalability and Limits [ID 370921.1]
- 身份验证模式变更
- (转载)如何解决TOMCAT的Tomcat's administration web application is no longer installed by default
- 解决WIN7无法访问WIN2000的共享
- 外贸公司的流程!
- Oracle Connect By用法