• 【dp专题1】F


    A subsequence of a given sequence is the given sequence with some elements (possible none) left out. Given a sequence X = <x1, x2, ..., xm> another sequence Z = <z1, z2, ..., zk> is a subsequence of X if there exists a strictly increasing sequence <i1, i2, ..., ik> of indices of X such that for all j = 1,2,...,k, xij = zj. For example, Z = <a, b, f, c> is a subsequence of X = <a, b, c, f, b, c> with index sequence <1, 2, 4, 6>. Given two sequences X and Y the problem is to find the length of the maximum-length common subsequence of X and Y. 
    The program input is from a text file. Each data set in the file contains two strings representing the given sequences. The sequences are separated by any number of white spaces. The input data are correct. For each set of data the program prints on the standard output the length of the maximum-length common subsequence from the beginning of a separate line. 
    Input
    abcfbc abfcab
    programming contest 
    abcd mnp
    Output
    4
    2
    0
    Sample Input
    abcfbc abfcab
    programming contest 
    abcd mnp
    Sample Output
    4
    2
    0
    #include<stdio.h>
    #include<string.h>
    
    int f[1000][1000];
    
    int main()
    {
        int l1,l2;
        int i,j;
        char s1[1000],s2[1000];
        while(scanf("%s%s",s1+1,s2+1)!=EOF)
        {
            l1 = strlen(s1+1);
            l2 = strlen(s2+1);
    
            for(i = 0; i <= l1;i ++)
                f[i][0] = 0;
            for(i = 0; i <= l2; i ++)
                f[0][i] = 0;
            for(i = 1; i <= l1; i ++)
            {
                for(j = 1; j <= l2; j ++)
                {
                    if(s1[i] == s2[j])
                    {
                        f[i][j] = f[i-1][j-1] + 1;
                    }
                    else
                    {
                        if(f[i-1][j] > f[i][j-1])
                            f[i][j] = f[i-1][j];
                        else
                            f[i][j] = f[i][j-1];
                    }
                }
            }
            printf("%d
    ",f[l1][l2]);
        }
        return 0;
    }
    
  • 相关阅读:
    Qt实战6.万能的无边框窗口(FramelessWindow)
    Qt实战5.如何获取USB设备信息?
    Qt实战4.简单封装的文件监控
    Qt实战3.Qt仿Win10风格界面
    Linux下使用脚本让程序顺序启动
    项目经验1.软件的开发过程
    Qt实战2.老生常谈的文件传输
    mysql导入txt文件
    linux离线安装python3
    mysql知识点
  • 原文地址:https://www.cnblogs.com/hellocheng/p/7350110.html
Copyright © 2020-2023  润新知