最长公共子序列

系统 1947 0

 

时间限制: 3000 ms  |  内存限制: 65535 KB
难度: 3
 
描述
咱们就不拐弯抹角了,如题,需要你做的就是写一个程序,得出最长公共子序列。
tip:最长公共子序列也称作最长公共子串(不要求连续),英文缩写为LCS(Longest Common Subsequence)。其定义是,一个序列 S ,如果分别是两个或多个已知序列的子序列,且是所有符合此条件序列中最长的,则 S 称为已知序列的最长公共子序列。
 
输入
第一行给出一个整数N(0<N<100)表示待测数据组数
接下来每组数据两行,分别为待测的两组字符串。每个字符串长度不大于1000.
输出
每组测试数据输出一个整数,表示最长公共子序列长度。每组结果占一行。
样例输入
        2

asdf

adfsd

123abc

abc123abc
      
样例输出
        3

6
      
View Code
            
               1
            
             #include<iostream>
            
2 #include<cstdio>
3 #include<cstring>
4 #define max(a,b) (a>b? a:b)
5 #define Max 1010
6 using namespace std;
7 char ch1[Max],ch2[Max];
8 int d[Max][Max];
9 int dp( int i, int j)
10 {
11 int ans= 0 ;
12 if (i< 0 ||j< 0 )
13 return 0 ;
14 if (d[i][j]!=- 1 )
15 return d[i][j];
16 if (ch1[i]==ch2[j])
17 ans=dp(i- 1 ,j- 1 )+ 1 ;
18 else
19 ans=max(dp(i- 1 ,j),dp(i,j- 1 ));
20 return d[i][j]=ans;
21 }
22 int main()
23 {
24 int t,n,m;
25 cin>>t;
26 while (t--)
27 {
28 memset(d,- 1 , sizeof (d));
29 scanf( " %s%s " ,ch1,ch2);
30 n=strlen(ch1);m=strlen(ch2);
31 cout<<dp(n- 1 ,m- 1 )<<endl;
32 }
33 return 0 ;
34 }

最长公共子序列


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论