转移方程:if(s1[i]==s2[j])c[i][j]=c[i-1][j-1]+1; else c[i][j]=max(c[i-1][j],c[i][j-1]);
#include<stdio.h> #include<string.h> int main() { int c[100][100]; char str1[100],str2[100]; while(scanf("%s %s",str1,str2)>0) { int len1=strlen(str1); int len2=strlen(str2); for(int i=0;i<len1;i++) c[i][0]=0; for(int i=0;i<len2;i++) c[0][i]=0; for(int i=1;i<=len1;i++) for(int j=1;j<=len2;j++) { if(str1[i-1]==str2[j-1]) c[i][j]=c[i-1][j-1]+1; else if(c[i-1][j]>c[i][j-1]) c[i][j]=c[i-1][j]; else c[i][j]=c[i][j-1]; } printf("%d\n",c[len1][len2]); } }