题目1042:Coincidence(最长公共子序列)

问题来源

  http://ac.jobdu.com/problem.php?pid=1042

问题描述

  给定两个字符串,求其最长公共子序列(LCS)。

问题分析

  网上是在是太多这类问题的文章了,随便贴一个吧。

  http://blog.csdn.net/yysdsyl/article/details/4226630/

参考代码

//
// Created by AlvinZH on 2017/6/22.
// Copyright (c) AlvinZH. All rights reserved.
//

#include <iostream>
#include <algorithm>
#include <cstring>

using namespace std;

string S,P;
int LCS[105][105];

int getLCS()
{
    int Slen = S.length();
    int Plen = P.length();

    memset(LCS,0, sizeof(LCS));

    for(int i=0;i<Slen;i++)
    {
        for(int j=0;j<Plen;j++)
        {
            if(S[i] == P[j])
                LCS[i+1][j+1] = LCS[i][j]+1;
            else
            {
                if(LCS[i+1][j] >= LCS[i][j+1])
                    LCS[i+1][j+1] = LCS[i+1][j];
                else
                    LCS[i+1][j+1] = LCS[i][j+1];
            }
        }
    }

    return LCS[Slen][Plen];
}

int main()
{
    while(cin>>S>>P)
    {
        cout<<getLCS()<<endl;
    }
}

 

作者: AlvinZH

出处: http://www.cnblogs.com/AlvinZH/

本人Github:https://github.com/Pacsiy/JobDu

本文版权归作者AlvinZH和博客园所有,欢迎转载和商用,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

转载于:https://www.cnblogs.com/AlvinZH/p/7063440.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值