动态规划解最长公共子序列(LCS)原理及模板

简介: 动态规划解最长公共子序列(LCS)原理及模板

最长公共子序列

1.LCS的概念

(1)递增 (2)可以连续可以不连续 (3)公共:在S1内,又在S2内 (4)最长:5(acdEH)>4(acdE)…

2.LCS的规律

下列图片来自动态规划解最长公共子序列(LCS)(附详细填表过程)

看了下面6张图,就可以得出上图的结论,从而递推出

if(s1[i-1]==s2[j-1])
    dp[i][j]=dp[i-1][j-1]+1;
else
    dp[i][j]=max(dp[i-1][j],dp[i][j-1]);

最长公共子序列的模板

1.动态规划求解LCS模板

#include<iostream>
#include<algorithm>
using namespace std;
int dp[1005][1005];
int main() {
  string s1,s2;
  while(cin>>s1>>s2) {
    int l1=s1.size();
    int l2=s2.size();
    for(int i=0; i<=l1; i++) {
      dp[0][i]=0;
      dp[i][0]=0;
    }
    for(int i=1; i<=l1; i++) {
      for(int j=1; j<=l2; j++) {
        if(s1[i-1]==s2[j-1])
          dp[i][j]=dp[i-1][j-1]+1;
        else
          dp[i][j]=max(dp[i-1][j],dp[i][j-1]);
      }
    }
    cout<<dp[l1][l2]<<endl;
  }
}

2. LCS字符串输出(还原)

看23-39行,1-23行代码是LCS长度的代码

#include<iostream>
#include<algorithm>
using namespace std;
int dp[1005][1005];
int main(){
    string s1,s2;
    while(cin>>s1>>s2){
        int l1=s1.size();
        int l2=s2.size();
        for(int i=0;i<=l1;i++){
            dp[0][i]=0;
            dp[i][0]=0;
        }
        for(int i=1;i<=l1;i++){
            for(int j=1;j<=l2;j++){
                if(s1[i-1]==s2[j-1])
                    dp[i][j]=dp[i-1][j-1]+1;
                else
                    dp[i][j]=max(dp[i-1][j],dp[i][j-1]);
            }
        }
        cout<<dp[l1][l2]<<endl;
        int i=l1,j=l2,z=0;
        string s3;
    while(i!=0 && j!=0){
      if(s1[i-1]==s2[j-1]){
        i--;
        j--;
        s3[z++]=s1[i];
      }
      else if(dp[i-1][j]<dp[i][j-1]){
        j--;
      }
      else if(dp[i-1][j]>=dp[i][j-1]){
        i--;
      }
    } 
    for(int i=z-1;i>=0;i--){
      cout<<s3[i];
    }
    cout<<endl;
    }
}


目录
相关文章
|
3月前
|
算法
动态规划算法学习二:最长公共子序列
这篇文章介绍了如何使用动态规划算法解决最长公共子序列(LCS)问题,包括问题描述、最优子结构性质、状态表示、状态递归方程、计算最优值的方法,以及具体的代码实现。
203 0
动态规划算法学习二:最长公共子序列
|
7月前
|
机器学习/深度学习 人工智能 JavaScript
技术心得记录:最长公共子序列(LCS)详解+例题模板(全)(转)
技术心得记录:最长公共子序列(LCS)详解+例题模板(全)(转)
|
8月前
【错题集-编程题】最长公共子序列(一)(动态规划 - LCS)
【错题集-编程题】最长公共子序列(一)(动态规划 - LCS)
|
8月前
|
人工智能
最长公共子序列(经典动态规划问题)
最长公共子序列(经典动态规划问题)
|
8月前
|
算法 程序员 索引
【算法训练-动态规划 三】【双序列DP问题】最长重复子数组、最长公共子串、最长公共子序列、编辑距离
【算法训练-动态规划 三】【双序列DP问题】最长重复子数组、最长公共子串、最长公共子序列、编辑距离
129 0
深入理解动态规划算法 | 最长公共子序列LCS
深入理解动态规划算法 | 最长公共子序列LCS
144 0
深入理解动态规划算法 - 最长公共子序列
深入理解动态规划算法 - 最长公共子序列
83 0
|
算法 关系型数据库 MySQL
浅谈最长公共子序列引发的经典动态规划问题
这篇文章通过一道经典例题:最长公共子序列,给大家讲讲动态规划,并且给出一道LeetCode周赛动态规划题作为练手并讲解,相信看完文章之后,你会对动态规划有更深的理解。
127 0
浅谈最长公共子序列引发的经典动态规划问题
|
算法
动态规划--最长上升子序列模型(二)
AcWing算法提高课内容,本文讲解 动态规划
97 0
动态规划--最长上升子序列模型(二)
|
算法
动态规划--最长上升子序列模型(一)
AcWing算法提高课内容,本文讲解 动态规划
159 0
动态规划--最长上升子序列模型(一)

热门文章

最新文章