动态规划之-最长公共子序列

代码如下:

///最长递增子序列

#include<string.h>
#include<stdlib.h>
#include<cstdio>
#include<iostream>
#define MAX(A,B) (A)>(B)?(A):(B)
using namespace std;
int main()
{
    char str1[100];
    char str2[100];
    int result_set[100][100];
    while(~scanf("%s%s",str1,str2))
    {
        int len1=strlen(str1);
        int len2=strlen(str2);
        memset(result_set,0,sizeof(result_set));
        for(int i=1,k=0; k<len1 ; i++,k++)
        {
            for(int j=1,c=0 ; c<len2 ; j++,c++)
            {
                if(str1[k]==str2[c])
                {
                    result_set[i][j]=result_set[i-1][j-1]+1;
                }
                else
                    result_set[i][j]=MAX(result_set[i-1][j],result_set[i][j-1]);
            }
        }
        for(int i=0; i<=len1 ; i++)
        {
            for(int j=0; j<=len2 ; j++)
            {

                cout<<result_set[i][j]<<" ";
            }
            cout<<endl;
        }
    }
    return 0;
}

问题分析:
str1和str2两个子序列求它们的最长公共子序列
我们用一个二维数组result_set[i][j]来存str1的[1,i]范围和str[1,j]范围的最长公共子序列的数量
并把[0-len1][0]和[0][0-len2]作为边界,值为0。

递推公式为:
if(str1[k]==str1[c])
{
result_set[i][j]=result_set[i-1][j-1]+1;
}
else
result_set[i][j]=MAX(result_set[i][j-1],result_set[j][i-1]);

当str1 和 str2为此情况时:
str1 [0] [1] [2] [3] [4]
a c b d a
str1 [0] [1] [2] [3]
b c a d
得到的result_set[len1][len2]的值如下:
递推图

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值