描述
我们称序列Z = < z
1, z
2, ..., z
k >是序列X = < x
1, x
2, ..., x
m >的子序列当且仅当存在
严格上升 的序列< i
1, i
2, ..., i
k >,使得对j = 1, 2, ... ,k, 有x
ij = z
j。比如Z = < a, b, f, c > 是X = < a, b, c, f, b, c >的子序列。
现在给出两个序列X和Y,你的任务是找到X和Y的最大公共子序列,也就是说要找到一个最长的序列Z,使得Z既是X的子序列也是Y的子序列。
输入
输入包括多组测试数据。每组数据包括一行,给出两个长度不超过200的字符串,表示两个序列。两个字符串之间由若干个空格隔开。
输出
对每组输入数据,输出一行,给出两个序列的最大公共子序列的长度。
样例输入
样例输出
感受:
现在给出两个序列X和Y,你的任务是找到X和Y的最大公共子序列,也就是说要找到一个最长的序列Z,使得Z既是X的子序列也是Y的子序列。
abcfbc abfcab programming contest abcd mnp
4 2 0
题意:
找出最长的公共子序列
分析:
用二维数组储存,如果a[i]==b[j]那么c[i][j]=c[i-1][j-1]+1;如果不相同那么c[i][j]=max(c[i-1][j],c[i][j-1]);
代码:
#include<bits/stdc++.h>
using namespace std;
int main()
{
string a,b;
int c[205][205],i,j,l1,l2;
while(cin>>a>>b)
{
memset(c,0,sizeof(c));
l1=a.size();
l2=b.size();
for(i=0;i<l1;i++)
for(j=0;j<l2;j++)
{
if(a[i]==b[j])
c[i+1][j+1]=c[i][j]+1;
else
c[i+1][j+1]=max(c[i+1][j],c[i][j+1]);
}
cout<<c[l1][l2]<<endl;
}
}
感受:
主要是储存数量的式子比较难想,想出来就觉得简单了。。。