最长公共子序列

http://972169909-qq-com.iteye.com/blog/1447946

http://www.cnblogs.com/cykun/archive/2011/02/17/1957184.html

http://blog.csdn.net/q3498233/article/details/5492481

http://blog.csdn.net/q3498233/article/details/5295082

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define MAXN 111
int dp[MAXN][MAXN];
char str1[MAXN],str2[MAXN];
int mark[MAXN];
int path[MAXN][MAXN];
int len1,len2;

int main(){
    while(~scanf("%s%s",str1,str2)){
        len1=strlen(str1);
        len2=strlen(str2);
        memset(dp,0,sizeof(dp));
        memset(path,0,sizeof(path));
        memset(mark,-1,sizeof(mark));
        for(int i=1;i<=len1;i++){
            for(int j=1;j<=len2;j++){
                if(str1[i-1]==str2[j-1]){
                    dp[i][j]=dp[i-1][j-1]+1;
                }else if(dp[i-1][j]>dp[i][j-1]){
                    dp[i][j]=dp[i-1][j];
                    path[i][j]=1;
                }else {
                    dp[i][j]=dp[i][j-1];
                    path[i][j]=2;
                }
            }
        }
        for(int i=len1,j=len2;i>=1&&j>=1;){
            if(path[i][j]==0){
                i--,j--;
                mark[i]=j;
            }else if(path[i][j]==1){
                i--;
            }else 
                j--;
        }
        int k=0;
        for(int i=0;i<len1;i++){
            if(mark[i]==-1){
                printf("%c",str1[i]);
            }else {
                for(int j=k;j<=mark[i];j++){
                    printf("%c",str2[j]);
                }
                k=mark[i]+1;
            }
        }
        for(int j=k;j<len2;j++)printf("%c",str2[j]);
        puts("");
    }
    return 0;
}




#include <stdio.h>
#include <string.h>
#define size 201

int Max(int x,int y)
{
return x>y?x:y;
}

struct rem 
{
int i,j;/*i记录主串位置,j记录副串当前字符位置*/
char ch;/*记录当前字符*/
};

char a[size],b[size];
int dp[size][size];
rem ans[size];
int len;/*指示ans的长度*/

void lcs(int m,int n)
{
int i,j;
memset(dp,0,sizeof(dp));
len = 0;
for (i=1;i<=m;i++)
{
for (j=1;j<=n;j++)
{
if(a[i]==b[j])
dp[i][j] = dp[i-1][j-1]+1;
else
dp[i][j] = Max(dp[i-1][j],dp[i][j-1]);
}
}
if(dp[m][n] == 0)/*如果没有公共序列,直接输出*/
printf("%s%s",a,b);
else
{
/*取出最长公共子序列的字母*/
i = m,j = n;
while (i!=0&&j!=0)
{
if ((dp[i][j] = dp[i-1][j-1]+1)&&a[i] == b[j])
{
ans[len].i = i;
ans[len].j = j;
ans[len++].ch = a[i];/*倒序保存最长公共子序列字母*/
i--,j--;
}
else if(dp[i-1][j]>dp[i][j-1])
i--;
else
j--;
}
/*取出最长公共子序列的字母*/
}
}

int main()
{
int a1,b1,i,j,k;
while (scanf("%s%s",a+1,b+1)!=EOF)
{
a1 = strlen(a+1);
b1 = strlen(b+1);
lcs(a1,b1);
i = j = 1;
for (k=len-1;k>=0;k--)
{
while (i!=ans[k].i)
{
printf("%c",a[i]);
i++;
}
while (j!=ans[k].j)
{
printf("%c",b[j]);
j++;
}
printf("%c",ans[k].ch);
i++,j++;
}
printf("%s%s/n",a+ans[0].i+1,b+ans[0].j+1);
}
return 0;
} 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值