首页 > 其他 > 详细

最长公共子序列

时间:2021-04-08 15:07:17      阅读:18      评论:0      收藏:0      [点我收藏+]

 

 

题目描述:

给定两个长度分别为 NN 和 MM 的字符串 AA 和 BB,求既是 AA 的子序列又是 BB 的子序列的字符串长度最长是多少。

输入格式

第一行包含两个整数 NN 和 MM。

第二行包含一个长度为 NN 的字符串,表示字符串 AA。

第三行包含一个长度为 MM 的字符串,表示字符串 BB。

字符串均由小写字母构成。

输出格式

输出一个整数,表示最大长度。

数据范围

1N,M10001≤N,M≤1000

 

输入样例:

4 5
acbd
abedc

输出样例:

3

代码:

dp:

 1 for (int i = 1; i <= n; i++) {
 2     for (int j = 1; j <= m; j++) {
 3       if (a[i] == b[j]) {
 4         f[i][j] = f[i - 1][j - 1] + 1;
 5       } else {
 6         f[i][j] = max(f[i - 1][j], f[i][j - 1]);
 7       }
 8     }
 9   }
10   cout << f[n][m] << \n;

 

ac:

 1 #include <iostream>
 2 using namespace std;
 3 
 4 int n,m;
 5 char a[1010],b[1010];
 6 int f[1010][1010];
 7 
 8 int main()
 9 {
10     cin >> n >> m;
11     for(int i = 1;i <= n;i++) cin >> a[i];
12     for(int i = 1;i <= m;i++) cin >> b[i];
13     
14     for(int i = 1; i<=n; i++)
15         for(int j = 1; j <= m;j ++)
16         {
17             if(a[i] == b[j]) f[i][j] = f[i-1][j-1] + 1;
18             else
19             {
20                 f[i][j] = max(f[i-1][j], f[i][j-1]);
21                 // 最长公共子序列, 倒数第二位不匹配的两种情况, 取最大值 即最长公共
22             }
23         }
24         
25         cout << f[n][m] << endl;
26     
27     return 0;
28 }

 

最长公共子序列

原文:https://www.cnblogs.com/leoaioliabao/p/14631167.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!