题目描述:若给定序列X={x1,x2,…,xm},则另一序列Z={z1,z2,…,zk},是X的子序列是指存在一个严格递增下标序列{i1,i2,…,ik}使得对于所有j=1,2,…,k有:zj=xij。例如,序列Z={B,C,D,B}是序列X={A,B,C,B,D,A,B}的子序列,相应的递增下标序列为{2,3,5,7}。
给定2个序列X和Y,当另一序列Z既是X的子序列又是Y的子序列时,称Z是序列X和Y的公共子序列。
给定2个序列X={x1,x2,…,xm}和Y={y1,y2,…,yn},找出X和Y的最长公共子序列。
代码如下:
#include <stdlib.h>
#include<stdio.h>
#include <string.h>
#define m 7
#define n 6
int c[m+1][n+1];
char b[m+1][n+1];
void LCSLength(char *x, char *y)
{
int i, j;
for (i = 1; i <= m; i++) c[i][0] = 0;
for (i = 1; i <= n; i++) c[0][i] = 0;
for (i = 1; i <= m; i++)
for (j = 1; j <= n; j++)
{
if (x[i] == y[j])
{
c[i][j] = c[i - 1][j - 1] + 1;
b[i][j] = 1;
}
else if (c[i - 1][j] >= c[i][j - 1])
{
c[i][j] = c[i - 1][j];
b[i][j] = 2;
}
else
{
c[i][j] = c[i][j - 1];
b[i][j] = 3;
}
}
}
void LCS(int i, int j, char *x)
{
if (i == 0 || j == 0)
return;
if (b[i][j] == 1)
{
LCS(i - 1, j - 1, x);
printf("%c", x[i]);
}
else if (b[i][j] == 2)
LCS(i - 1, j, x);
else
LCS(i, j - 1, x);
}
int main()
{
int i, j;
char X[m];
char Y[n];
printf("请输入序列X:");
for (int i = 1; i <= m; i++)
{
scanf_s("%c", &X[i]);
}
printf("请输入序列Y:");
for (int i = 1; i <= n; i++)
{
scanf_s("%c", &Y[i]);
}
LCSLength(X, Y);
printf("LCS长度表c:\n");
for (i = 1; i <= m; i++)
{
for (j = 1; j <= n; j++)
printf("%d ", c[i][j]);
printf("\n");
}
printf("路径表b:\n");
for (i = 1; i <= m; i++)
{
for (j = 1; j <= n; j++)
printf("%c ", b[i][j]);
printf("\n");
}
printf("\nLCS是:\n");
printf("\n");
LCS(m, n,X);
system("PAUSE");
return 0;
}
学习中,欢迎交流,指导