题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2476

题目大意:给你字符串A、B,每次操作可以将一段区间刷成任意字符,问最少需要几次操作可以使得字符串A等于B。
解题思路:

先计算出将空串刷成字符串B的最小操作数,再去计算将A串刷成B串的最小操作数。

设dp[i][j]表示将空串[i,j]刷成跟B串一样的最小操作次数,所以得到状态转移方程:

dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+1][j]),(i<=k<j)
if(_str[i]==_str[j])
  dp[i][j]--;

这里跟LightOJ 1422 写法差不多。

接下来设ans[i]表示将字符串A的[0,i]刷成B的最小操作次数,得到状态转移方程:

ans[i]=min(ans[i],ans[j]+dp[j+1][i]),(0<=j<i)

代码

 #include<cstdio>
#include<cmath>
#include<cctype>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<vector>
#include<queue>
#include<set>
#include<map>
#include<stack>
#include<string>
#define lc(a) (a<<1)
#define rc(a) (a<<1|1)
#define MID(a,b) ((a+b)>>1)
#define fin(name) freopen(name,"r",stdin)
#define fout(name) freopen(name,"w",stdout)
#define clr(arr,val) memset(arr,val,sizeof(arr))
#define _for(i,start,end) for(int i=start;i<=end;i++)
#define FAST_IO ios::sync_with_stdio(false);cin.tie(0);
using namespace std;
typedef long long LL;
const int N=5e2+;
const int INF=0x3f3f3f3f;
const double eps=1e-; int ans[N],dp[N][N];
char str[N],_str[N]; int main(){
while(~scanf("%s",str)){
scanf("%s",_str);
int n=strlen(str);
for(int i=;i<n;i++){
dp[i][i]=;
}
//写法跟lightoj 1422 那个换装类似
for(int len=;len<n;len++){
for(int i=;i+len<n;i++){
int j=i+len;
dp[i][j]=dp[i][j-]+;
for(int k=i;k<=j;k++){
dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+][j]);
}
if(_str[i]==_str[j])
dp[i][j]--;
}
}
for(int i=;i<n;i++){
ans[i]=dp[][i];
if(str[i]==_str[i]){
if(i==) ans[]=;
else ans[i]=ans[i-];
}
for(int j=;j<i;j++)
ans[i]=min(ans[i],ans[j]+dp[j+][i]);
}
printf("%d\n",ans[n-]);
}
return ;
}

最新文章

  1. html input节点很多 json字符串提交解决方法
  2. 转载 教你使用PS来制作unity3D随机地形
  3. mac os利用xampp实现apache下的cgi
  4. ios frame bounds applicationframe
  5. WP8__实现ListBox横向滑动及子项绑定图片等控件
  6. Visual Studio 2012 主题下的代码配色方案
  7. Qt configure 参数不完全说明
  8. Cocos2dx项目启程一 之 封装属于我的精灵类
  9. C# 截取图片区域,并返回所截取的图片
  10. Repcached实现memcached复制
  11. jquery 变量和原生js变量的关系
  12. Python基础学习-&#39;module&#39; object has no attribute &#39;urlopen&#39;解决方法
  13. 分布式一致性协议Raft原理与实例
  14. sql语言不经常用,复习
  15. 用spark-submit启动程序
  16. scala_1
  17. vue项目中主要文件的加载顺序(index.html、App.vue、main.js)
  18. 工具 docker
  19. Linux基础命令---显示树形进程pstree
  20. gulp 编译es6 react 教程 案例 配置

热门文章

  1. [THUSC 2016] 补退选 (Trie树)
  2. oracle的loop
  3. jQuery EasyUI 下拉菜单获取日期,最高年份为当前年份,最低年份为当前年份向前推10年
  4. 列表批量删除和单个删除共用一个方法传递集合到Controller
  5. 在ubuntu下安装opencv
  6. App统计指标定义
  7. linux环境下安装PHP扩展swoole
  8. numpy基础整理
  9. 【重要】Nginx模块Lua-Nginx-Module学习笔记(三)Nginx + Lua + Redis 已安装成功(非openresty 方式安装)
  10. Redis学习二:Redis入门介绍