最长公共子序列

题目链接

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]
};
相关推荐
云水一下39 分钟前
CSS3从零基础到精通(一):前世今生与基础入门
前端·css3
顾凌陵42 分钟前
CSRF&SSRF漏洞攻击的溯源分析与实战
前端·csrf
月月大王的3D日记44 分钟前
Three.js 材质篇(中):从兰伯特到PBR,一篇文章看懂五种光照材质
前端·javascript
且白1 小时前
leaflet切片变色、地图滤镜逻辑实现 colorfilter
前端·javascript
莫等闲-1 小时前
leetcode42. 接雨水 leetcode84.柱状图中最大的矩形
数据结构·c++·算法·leetcode
浅念-1 小时前
LeetCode 记忆化搜索 刷题总结
数据结构·算法·leetcode·职场和发展·深度优先·dfs
用户887665426631 小时前
Linux 终端入门:新手必须掌握的常用命令和基本思路
前端·操作系统
用户125758524361 小时前
Vue3 后台框架的网络请求怎么设计?看 XYGo Admin 三套 Axios 实例与拦截器方案
前端
菜菜的顾清寒1 小时前
力扣HOT100(44)对称二叉树
数据结构·算法·leetcode
ZengLiangYi1 小时前
多格式文件解析:JSONL / SQLite / Event Stream
前端·javascript·后端