hdu2476String painter (区间DP)
Posted lxjshuju
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hdu2476String painter (区间DP)相关的知识,希望对你有一定的参考价值。
zzzzzfzzzzz abcdefedcba abababababab cdcdcdcdcdcd
6 7题意:给定两个字符串a和b,求最少须要对a进行多少次操作,才干将a变成b。每次操作时将a中随意一段变成随意一个字母所组成的段。#include<stdio.h> #include<string.h> int min(int a,int b) { return a>b?b:a; } int main() { int dp[105][105],ans[105]; char a[105],b[105]; while(scanf("%s%s",a,b)>0) { int len=strlen(a); memset(dp,0,sizeof(dp)); for(int r=0;r<len;r++) for(int i=0;i<len-r;i++) { int j=i+r; dp[i][j]=dp[i+1][j]+1; for(int k=i+1;k<=j;k++) if(b[i]==b[k]) dp[i][j]=min(dp[i][j],dp[i+1][k]+dp[k+1][j]); } for(int i=0;i<len; i++) ans[i]=dp[0][i]; for(int i=0;i<len; i++) if(a[i]==b[i]) { if(i==0)ans[i]=0; else ans[i]=ans[i-1]; } else{ for(int k=0;k<i;k++) ans[i]=min(ans[i],ans[k]+dp[k+1][i]); } printf("%d\n",ans[len-1]); } }
以上是关于hdu2476String painter (区间DP)的主要内容,如果未能解决你的问题,请参考以下文章
HDU 2476 String painter (区间DP)