news 2026/4/23 21:47:09

力扣刷题:最长公共子序列

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣刷题:最长公共子序列

题目:
给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。

一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。

  • 例如,“ace” 是 “abcde” 的子序列,但 “aec” 不是 “abcde” 的子序列。

两个字符串的 公共子序列 是这两个字符串所共同拥有的子序列。

示例 1:

输入:text1 = “abcde”, text2 = “ace”
输出:3
解释:最长公共子序列是 “ace” ,它的长度为 3 。

示例 2:

输入:text1 = “abc”, text2 = “abc”
输出:3
解释:最长公共子序列是 “abc” ,它的长度为 3 。

示例 3:

输入:text1 = “abc”, text2 = “def”
输出:0
解释:两个字符串没有公共子序列,返回 0 。

解析:
这道题解法就是动态规划问题,主要是dp数组的设计:
dp[i][j] 表示字符串 text1 的前 i 个字符和 text2 的前 j 个字符的最长公共子序列长度。
对dp数组初始化:
dp[0][j] = 0:第一个字符串为空时,公共子序列长度为0。
dp[i][0] = 0:第二个字符串为空时,公共子序列长度为0。

如果 text1[i-1] == text2[j-1],说明当前字符可以匹配,所以:dp[i][j] = dp[i-1][j-1] + 1
如果不相等,只能看:dp[i][j] = max(dp[i-1][j], dp[i][j-1])
(要么丢弃 text1 的当前字符,要么丢弃 text2 的当前字符,看哪种更优)

具体代码:

/** * @param {string} text1 * @param {string} text2 * @return {number} */varlongestCommonSubsequence=function(text1,text2){constm=text1.lengthconstn=text2.lengthconstdp=Array.from({length:m+1},()=>Array(n+1).fill(0))//遍历两个字符串for(leti=1;i<=m;i++){for(letj=1;j<=n;j++){// 如果字符相同,最长公共子序列长度加1if(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])}}}returndp[m][n]};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 17:07:45

5、Unix 终端使用指南:从基础到定制

Unix 终端使用指南:从基础到定制 1. 了解 Shell 提示符 当系统准备好运行命令时,Shell 会输出一个提示符,提示你可以输入命令。在 bash 中,默认的提示符包含计算机名称、当前目录(可能用 ~ 表示家目录)、登录名和美元符号。例如: Dave-Taylors-MacBook-Pro:~ tayl…

作者头像 李华
网站建设 2026/4/23 14:53:31

8、文件权限与磁盘管理全解析

文件权限与磁盘管理全解析 1. 文件权限基础 在查看文件信息时,我们会注意到列出文件所有者、所属组以及访问模式(即权限)的列。默认情况下,创建文件的人就是文件的所有者,文件所属组通常是创建者所在的组,或者是文件所在目录的所属组。 文件模式由 10 个字符组成,第一…

作者头像 李华
网站建设 2026/4/23 17:44:25

9、操作系统文件管理与操作指南

操作系统文件管理与操作指南 1. 文件写入问题排查 当遇到文件可写,但程序提示无法写入的问题时,可按以下步骤排查: 1. 使用 ls -l 命令检查文件权限,确保你属于具有写入权限的类别(用户、组或其他)。 2. 问题可能出在文件所在目录的权限上。有些程序在编辑时需要向…

作者头像 李华
网站建设 2026/4/23 14:40:22

10、Mac 系统文件操作与编辑全攻略

Mac 系统文件操作与编辑全攻略 在 Mac 系统中,我们常常需要对文件进行各种操作,如移动、查看内容、创建和编辑等。本文将详细介绍一些实用的命令行工具和方法,帮助你更高效地管理和处理文件。 1. 文件移动 如果你想快速将当前目录下的所有 JPG 图片文件移动到一个名为 “…

作者头像 李华
网站建设 2026/4/23 16:05:14

AI如何智能实现list转string?快马平台一键生成代码

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请使用Kimi-K2模型生成一个Python函数&#xff0c;将包含混合数据类型&#xff08;字符串、数字、布尔值&#xff09;的list转换为以逗号分隔的string。要求处理None值转为空字符串…

作者头像 李华
网站建设 2026/4/23 19:14:20

Flowable开发效率对比:传统编码 vs AI辅助生成

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请分别用传统方式和AI生成方式实现同一个采购审批流程&#xff1a;1.员工提交采购申请 2.部门预算检查(自动) 3.部门经理审批 4.财务复核 5.采购执行。传统方式请给出典型代码量估算…

作者头像 李华