博客
关于我
寒假训练补题-第六天-D4-最长公共子序列dp-容易
阅读量:164 次
发布时间:2019-02-28

本文共 1288 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要找到两个字符串的最大长度公共子序列的长度。子序列的定义是元素的顺序保持不变,但不需要连续。我们可以使用动态规划的方法来解决这个问题。

方法思路

  • 问题分析:我们需要找到两个字符串的最大长度公共子序列。子序列的定义是元素的顺序保持不变,但不需要连续。例如,给定两个字符串X和Y,我们需要找到它们的最大长度公共子序列。
  • 动态规划:我们可以使用一个二维数组dp,其中dp[i][j]表示X的前i个字符和Y的前j个字符形成的最大长度公共子序列的长度。
  • 状态转移:当s1[i]等于s2[j]时,dp[i][j] = dp[i-1][j-1] + 1。否则,dp[i][j]取决于前面i-1,j和i,j-1的最大值。
  • 初始化:当i或j为0时,dp[i][j]为0,因为没有字符可以匹配。
  • 解决代码

    #include 
    #include
    #include
    using namespace std;int main() { char s1[1005], s2[1005]; int len1, len2; while (scanf("%s %s", s1 + 1, s2 + 1) != EOF) { memset(dp, 0, sizeof(dp)); len1 = strlen(s1 + 1); len2 = strlen(s2 + 1); for (int i = 1; i <= len1; ++i) { for (int j = 1; j <= len2; ++j) { if (s1[i] == s2[j]) { dp[i][j] = dp[i-1][j-1] + 1; } else { dp[i][j] = max(dp[i-1][j], dp[i][j-1]); } } } printf("%d\n", dp[len1][len2]); } return 0;}

    代码解释

  • 读取输入:使用scanf函数读取输入的两个字符串,确保正确处理多个空格分隔的输入。
  • 初始化动态规划数组:使用memset初始化一个二维数组dp,其大小为1005 x 1005,以避免越界错误。
  • 填充动态规划数组:使用双重循环遍历每个字符位置,更新dp数组。对于每个位置,如果当前字符相等,则取前左上角的值加1,否则取左边或上边的最大值。
  • 输出结果:对于每组输入,输出dp数组在最后一行的值,即两个字符串的最大长度公共子序列的长度。
  • 这种方法确保我们能够高效地计算出最大长度公共子序列的长度,时间复杂度为O(mn),其中m和n分别是两个字符串的长度。

    转载地址:http://lwtj.baihongyu.com/

    你可能感兴趣的文章
    SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
    查看>>
    Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
    查看>>
    pandas DataFrame 中的自定义浮点格式
    查看>>
    Pandas 读取具有浮点值的 csv 文件会导致奇怪的舍入和小数位数
    查看>>
    pandas 适用,但仅适用于满足条件的行
    查看>>
    Pandas-通过对列和索引的值求和来合并两个数据框
    查看>>
    pandas.read_csv()的详解-ChatGPT4o作答
    查看>>
    Pandas数据可视化怎么做?用实战案例告诉你!
    查看>>
    Pandas数据结构之DataFrame常见操作
    查看>>
    pandas整合多份csv文件
    查看>>
    pandas某一列转数组list
    查看>>
    pandas的to_sql方法中使用if_exists=‘replace‘
    查看>>
    Parallel.ForEach的基础使用
    查看>>
    parallels desktop for mac安装虚拟机 之parallelsdesktop密钥 以及 parallels desktop安装win10的办公推荐可以提高办公效率...
    查看>>
    PATA1038题解(需复习)
    查看>>
    Path does not chain with any of the trust anchors
    查看>>
    Path形状获取字符串型变量数据
    查看>>
    PAT甲级——1006 Sign In and Sign Out (25分)
    查看>>
    PAT甲级——1007 Maximum Subsequence Sum (25分)
    查看>>
    PAT甲级——1009 Product of Polynomials (25分)(最后一个测试点段错误)
    查看>>