zoukankan      html  css  js  c++  java
  • POJ 1458 Common Subsequence (DP+LCS,最长公共子序列)

    题意:给定两个字符串,让你找出它们之间最长公共子序列(LCS)的长度。

    析:很明显是个DP,就是LCS,一点都没变。设两个序列分别为,A1,A2,...和B1,B2..,d(i, j)表示两个字符串LCS长度。

    当A[i] = B[j] 时,这个最长度就是上一个长度加1,即:d(i, j) = d(i-1, j-1) + 1;

    当A[i] != B[j] 时,那就是前面的最长长度(因为即使后面的不成立,也不会影响前面的),即:d(i, j) = max{d(i-1, j), d(i, j-1)}。

    时间复杂度为mn,其中m,n分别为两个序列的长度。

    代码如下:

    #include <iostream>
    #include <cstring>
    #include <vector>
    #include <algorithm>
    #include <cstdio>
    
    using namespace std;
    const int maxn = 1000 + 10;
    char s1[maxn], s2[maxn];
    int d[maxn][maxn];
    
    int main(){
        while(~scanf("%s", s1+1)){
            scanf("%s", s2+1);
            int len1 = strlen(s1+1);
            int len2 = strlen(s2+1);
    
            memset(d, 0, sizeof(d));
            for(int i = 1; i <= len1; ++i)
                for(int j = 1; j <= len2; ++j)
                    if(s1[i] == s2[j])  d[i][j] = d[i-1][j-1] + 1;
                    else  d[i][j] = max(d[i-1][j], d[i][j-1]);
    
            printf("%d
    ", d[len1][len2]);
        }
        return 0;
    }
    
  • 相关阅读:
    sys模块
    反射
    动态导入模块
    类的静态属性
    多态
    继承
    组合
    linux系统各个子目录的内容
    mysql安装
    Docker 数据卷操作
  • 原文地址:https://www.cnblogs.com/dwtfukgv/p/5525514.html
Copyright © 2011-2022 走看看