用C++代码动态规划解决最长公共子序列问题 要求 给出两个字符序列 输出最长公共子序列的长度 以及 所有最长公共子序列的情况 当最长公共子序列为空时,输出最长公共子序列长度为0,最长公共子序列为:None。 【样例1输入】 A B C B D A B B D C A B A 【样例1输出】 4 BCBA BDAB
时间: 2024-02-12 16:04:12 浏览: 63
好的,下面是用 C++ 实现的动态规划算法解决最长公共子序列问题的代码:
```cpp
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
string X, Y;
cin >> X >> Y;
int m = X.length(), n = Y.length();
vector<vector<int>> dp(m+1, vector<int>(n+1, 0)); // 初始化 dp 数组
for (int i = 1; i <= m; ++i) {
for (int j = 1; j <= n; ++j) {
if (X[i-1] == Y[j-1]) { // 当前字符相等
dp[i][j] = dp[i-1][j-1] + 1;
} else { // 当前字符不相等
dp[i][j] = max(dp[i-1][j], dp[i][j-1]);
}
}
}
int len = dp[m][n]; // 最长公共子序列的长度
if (len == 0) { // 特判:最长公共子序列为空
cout << "0 None" << endl;
return 0;
}
cout << len << " ";
vector<string> lcs; // 存储所有最长公共子序列
string cur = "";
int i = m, j = n;
while (i > 0 && j > 0) {
if (X[i-1] == Y[j-1]) { // 当前字符相等,加入到当前子序列中
cur = X[i-1] + cur;
--i, --j;
} else { // 当前字符不相等,回溯到 dp 值较大的那个方向
if (dp[i-1][j] >= dp[i][j-1]) {
--i;
} else {
--j;
}
}
if (cur.length() == len) { // 当前子序列长度等于最长公共子序列长度,加入到结果中
lcs.push_back(cur);
}
}
sort(lcs.begin(), lcs.end()); // 按字典序排序
for (string s : lcs) {
cout << s << " ";
}
cout << endl;
return 0;
}
```
这个算法的时间复杂度为 $O(mn)$,空间复杂度也为 $O(mn)$。
阅读全文