最长公共子序列

题目链接

1143. 最长公共子序列 - 力扣(LeetCode)

思路:

  1. 首先了解到题目所说的子序列指的是,只要顺序能对的上,就算子序列

  2. 我们考虑到本题,适合使用 dp 动态规划思想去做,对于 text1 text2 俩个字符串,我们模拟取最大值, dpij 数组 代表了 texti-1 和 textj-1 当前元素字符串所能得到的 最大子序列的结果值,那么我们需要特殊考虑 当 dp0j dpi0 的元素,这些都需要赋初值为0,

  3. dpij 会出现俩种情况,text1i-1 等于 text2j-1 或者不相等,首先我们看相等的情况,相等的话 dpij 应该是等于 dpi-1j-1+1 等于在不包含本次相等情况的字符时,所得到的最大值 +1

text1i-1 和 text2j-1 不相等的情况那就是,需要比较,在 不取text1当前位置 i-1 的情况,以及 不取 text2 当前位置 j-1 的情况,俩个之中的最大值。就能得到当前位置的结果,简单说就是,不包含 当前位置 i 的字符元素 或者 当前位置 j 的字符元素

代码:

javascript 复制代码
/**
 * @param {string} text1
 * @param {string} text2
 * @return {number}
 */
var longestCommonSubsequence = function (text1, text2) {
    let dp = new Array(text1.length + 10).fill(0).map(item => new Array(text2.length + 10).fill(0))

    for (let i = 0; i <= text1.length; i++) {
        for (let j = 0; j <= text2.length; j++) {
            if (i == 0 || j == 0) {
                dp[i][j] = 0
                continue
            }
            if (text1[i - 1] === text2[j - 1]) {
                dp[i][j] = dp[i - 1][j - 1] + 1
            }
            else dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1])
        }
    }

    return dp[text1.length][text2.length]
};
相关推荐
kyriewen18 小时前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
user205855615181320 小时前
Windows 项目安装时报 `node-sass` 错误,如何快速处理
前端
LiaCode20 小时前
Redis 在生产项目的使用
前端·后端
LiaCode20 小时前
一天学完 redis 的爽翻版核心知识总结
前端·后端
大刚测试开发实战20 小时前
如何内网穿透访问本地私有化部署的TestHub
前端·后端·github
风骏时光牛马20 小时前
# Ruby基于Rails框架实现多角色权限管理与数据分页查询完整实战代码案例
前端
weedsfly20 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
xiaodaoluanzha20 小时前
迄今為止,最簡單的編程語言 Nolang
前端·后端
Csvn20 小时前
Fetch 请求竞态终结者:AbortController 不只是用来"取消"的
前端
阡陌Jony20 小时前
关于前端路由中的参数问题的学习(一): params,query, hash(#)
前端