首页 > 代码库 > hdu 2476 String painter
hdu 2476 String painter
http://acm.hdu.edu.cn/showproblem.php?pid=2476
先从空白串变成字符串2,dp处理,dp[i][j]表示i到j区间的最小操作数。 然后在计算从字符串1变成字符串2的最小操作数。
1 #include <cstdio> 2 #include <cstring> 3 #include <algorithm> 4 using namespace std; 5 6 char s1[110],s2[110]; 7 int dp[110][110]; 8 int c[110]; 9 10 int main()11 {12 while(scanf("%s%s",s1,s2)!=EOF)13 {14 int n=strlen(s1);15 for(int i=0; i<n; i++)16 {17 for(int j=i; j<n; j++)18 {19 dp[i][j]=j-i+1;20 }21 }22 for(int i=n-2; i>=0; i--)23 {24 for(int j=i+1; j<n; j++)25 {26 dp[i][j]=dp[i+1][j]+1;27 for(int k=i+1; k<=j; k++)28 {29 if(s2[i]==s2[k])30 dp[i][j]=min(dp[i][j],dp[i+1][k-1]+dp[k][j]);31 }32 }33 }34 for(int i=0; i<n; i++)35 {36 c[i]=dp[0][i];37 if(s1[i]==s2[i])38 {39 if(i==0) c[i]=0;40 else c[i]=c[i-1];41 }42 for(int j=0; j<i; j++)43 {44 c[i]=min(c[i],c[j]+dp[j+1][i]);45 }46 }47 printf("%d\n",c[n-1]);48 }49 return 0;50 }
hdu 2476 String painter
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。