为什么输不出结果 帮忙看一下
问题描述我们称序列Z=<z1,z2, ...,zk>是序列X=<x1,x2,...,xm>的子序列当且仅当存在严格上升的序列<i1,i2,...,ik>,使得对j=1,2,...,k, 有xij=zj。比如Z=<a,b,f,c> 是X=<a,b,c,f,b,c>的子序列。
现在给出两个序列X和Y,你的任务是找到X和Y的最大公共子序列,也就是说要找到一个最长的序列 Z,使得Z既是X的子序列也是Y的子序列。
输入
输入包括多组测试数据。每组数据包括一行,给出两个长度不超过200的字符串,表示两个序列。两个字符串之间由若干个空格隔开。
输出
对每组输入数据,输出一行,给出两个序列的最大公共子序列的长度。
输入样例
abcfbc abfcab
programming contest
abcd mnp
输出样例
4
2
0
#include<stdio.h>
int main()
{
char a[200],b[200];
int i,j,d,e,f;
while(scanf("%s",&a[0])!=EOF)
{
for(i=1;a[i]!=' ';i++)
{
scanf("%s",&a[i]);
d++;
}
for(i=0;b[i]!='\n';i++)
{
scanf("%s",&b[i]);
e++;
}
f=0;
for(i=0;i<d;i++)
{
for(j=0;j<e;j++)
{
if(a[i]==b[j])
{
f++;
}
}
}
printf("%d\n",f);
}
return 0;
}
输不出结果。。。。。。。。。。。。。。。。。