递归算法求解最长公共子序列,并输出最长公共子序列
时间: 2023-08-13 14:53:48 浏览: 103
非常抱歉,之前提供的代码存在错误。以下是修复后的递归算法,用于求解最长公共子序列并输出结果:
```c
#include <stdio.h>
#include <string.h>
int max(int a, int b) {
return (a > b) ? a : b;
}
void printLCS(char *str1, char *str2, int m, int n, int dp[m+1][n+1]) {
if (m == 0 || n == 0) {
return;
}
if (str1[m - 1] == str2[n - 1]) {
printLCS(str1, str2, m - 1, n - 1, dp);
printf("%c", str1[m - 1]);
}
else if (dp[m-1][n] > dp[m][n-1]) {
printLCS(str1, str2, m - 1, n, dp);
}
else {
printLCS(str1, str2, m, n - 1, dp);
}
}
int LCS(char *str1, char *str2, int m, int n) {
if (m == 0 || n == 0) {
return 0;
}
if (str1[m - 1] == str2[n - 1]) {
return 1 + LCS(str1, str2, m - 1, n - 1);
}
else {
return max(LCS(str1, str2, m - 1, n), LCS(str1, str2, m, n - 1));
}
}
int main() {
char str1[] = "AGGTAB";
char str2[] = "GXTXAYB";
int m = strlen(str1);
int n = strlen(str2);
int dp[m+1][n+1];
int lcsLength = LCS(str1, str2, m, n);
printf("Longest Common Subsequence Length: %d\n", lcsLength);
printLCS(str1, str2, m, n, dp);
return 0;
}
```
请尝试运行修复后的代码,它将通过递归算法求解最长公共子序列,并输出结果。
阅读全文