代码如下:
///最长递增子序列
#include<string.h>
#include<stdlib.h>
#include<cstdio>
#include<iostream>
#define MAX(A,B) (A)>(B)?(A):(B)
using namespace std;
int main()
{
char str1[100];
char str2[100];
int result_set[100][100];
while(~scanf("%s%s",str1,str2))
{
int len1=strlen(str1);
int len2=strlen(str2);
memset(result_set,0,sizeof(result_set));
for(int i=1,k=0; k<len1 ; i++,k++)
{
for(int j=1,c=0 ; c<len2 ; j++,c++)
{
if(str1[k]==str2[c])
{
result_set[i][j]=result_set[i-1][j-1]+1;
}
else
result_set[i][j]=MAX(result_set[i-1][j],result_set[i][j-1]);
}
}
for(int i=0; i<=len1 ; i++)
{
for(int j=0; j<=len2 ; j++)
{
cout<<result_set[i][j]<<" ";
}
cout<<endl;
}
}
return 0;
}
问题分析:
str1和str2两个子序列求它们的最长公共子序列
我们用一个二维数组result_set[i][j]来存str1的[1,i]范围和str[1,j]范围的最长公共子序列的数量
并把[0-len1][0]和[0][0-len2]作为边界,值为0。
递推公式为:
if(str1[k]==str1[c])
{
result_set[i][j]=result_set[i-1][j-1]+1;
}
else
result_set[i][j]=MAX(result_set[i][j-1],result_set[j][i-1]);
当str1 和 str2为此情况时:
str1 [0] [1] [2] [3] [4]
a c b d a
str1 [0] [1] [2] [3]
b c a d
得到的result_set[len1][len2]的值如下: