zoukankan      html  css  js  c++  java
  • 最长公共子序列(LCS)

    1. 描述:

    给定两个字符串(或数字序列)A和B,求一个字符串,使得这个字符串是A和B的最长公共部分(子序列可以不连续)。

    2. 例子:

    如字符串“sadstory” 和 “adminsorry”的最长公共子序列为“adsory”,长度为6。

    3. 动态规划解法:

    设字符串A,B的长度分别为n,m。

    1)令dp[i][j] 表示字符串A的 i 号位和字符串B的 j 号位之前的LCS的长度(下标从1开始)。如dp[4][5]表示“sads”与“admin”的LCS长度。

    2)若A[i] == B[j],则字符串A与字符串B的LCS增加了1位,即dp[i][j] = dp[i-1][j-1] +1。

    3)若A[i] != B[j],则字符串A的i号位和字符串B的j号位之前的LCS无法延长,因此dp[i][j] 将会继承dp[i-1][j] 与 dp[i][j-1]中的较大值,即有dp[i][j] = max{ dp[i-1][j], dp[i][j-1] }。

    4)可以得到状态转移方程:

    •   dp[i][j] = dp[i-1][j-1] +1                     A[i] == B[j]
    •   dp[i][j] = max{ dp[i-1][j], dp[i][j-1] }        A[i] != B[j]
    •   边界:dp[i][0] == dp[0][j] ==0   (0≤i≤n,0≤j≤m)

    5)时间复杂度为O(mn)。

     1 #include<cstdio>
     2 #include <cstring>
     3 #include <algorithm>
     4 using namespace std;
     5 const int N = 100;
     6 char A[N], B[N];
     7 int dp[N][N];
     8 int main(){
     9     int n;
    10     gets(A+1);  //从下标为1开始读人
    11     gets(B+1);
    12     int lenA = strlen(A+1); //读取长度也相应的从+1开始
    13     int lenB = strlen(B+1);
    14     //边界
    15     for (int i=0; i<=lenA; i++) {
    16         dp[i][0] = 0;
    17     }
    18     for (int j=0; j<=lenB; j++) {
    19         dp[0][j] = 0;
    20     }
    21     //状态转移方程
    22     for (int i=1; i<=lenA; i++) {
    23         for (int j=1; j<=lenB; j++) {
    24             if (A[i]==B[j]) {
    25                 dp[i][j] = dp[i-1][j-1] + 1;
    26             }
    27             else{
    28                 dp[i][j] = max(dp[i-1][j], dp[i][j-1]);
    29             }
    30         }
    31     }
    32     printf("%d
    ",dp[lenA][lenB]);   //dp[lenA][lenB] 是答案
    33     return 0;
    34 }

     4. 注意:

    代码中边界和状态转移方程的循环终止条件都是小于等于字符串的长度。

  • 相关阅读:
    Java 时钟
    mybatis中的#和$的区别
    vuex数据管理-数据共享
    vuex数据管理-数据适配
    vue双向数据绑定原理
    基于VUE的SPA单页应用开发-加载性能篇
    vue2.0读书笔记3
    移动端软键盘收起监听
    移动端模态窗口的滚动和橡皮筋问题解决方案
    window.history的跳转实质-HTML5 history API 解析
  • 原文地址:https://www.cnblogs.com/Bella2017/p/9326395.html
Copyright © 2011-2022 走看看