acgo题库
  • 首页
  • 题库
  • 题单
  • 竞赛
  • 讨论
  • 排行
  • 团队
  • 备赛专区

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
登录
注册
题目详情题解(0)讨论(0)提交记录(0)
  • ACgo老六

    6

    userId_undefined

    bits/stdc++.h

    倔强青铜
    28阅读
    0回复
    4点赞
  • 解题思路

    我们可以使用一个二维数组 dp 来存储 X 和 Y 的公共子序列的长度。dp[i][j] 表示 X 的前 i 个元素和 Y 的前 j 个元素的公共子序列的长度。 首先初始化一个二维数组 dp,并将所有元素设置为 0。然后,我们使用两个循环来计算 dp[i][j] 的值。如果 X 的第 i 个元素和 Y 的第 j 个元素相同,我们将 dp[i][j] 设置为 dp[i - 1][j - 1] + 1,否则我们将 dp[i][j] 设置为 max(dp[i - 1][j], dp[i][j - 1])。最后,我们输出 dp[m][n],即 X 和 Y 的最长公共子序列的长度。

    userId_undefined

    我是垃圾

    荣耀黄金
    45阅读
    0回复
    1点赞
  • 来一个数字版的

    userId_undefined

    漩涡博人[秽土转生]

    倔强青铜
    12阅读
    0回复
    0点赞
首页