当前位置: 首页 > news >正文

LeetCode热题100-最长公共子序列

给定两个字符串text1text2,返回这两个字符串的最长公共子序列的长度。如果不存在公共子序列,返回0

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

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

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

首先明确概念字串是连续的字符,子序列是不保证连续,但是保证前后顺序。经典二维 DP 题,

核心思路

  • 状态:dp[i][j]表示text1[0..i-1]text2[0..j-1]的最长公共子序列长度
  • 转移:
    • 字符相等:dp[i][j] = dp[i-1][j-1] + 1
    • 不等:dp[i][j] = max(dp[i-1][j], dp[i][j-1])
空 a c 空 0 0 0 a 0 1 1 b 0 1 1 c 0 1 2
class Solution: def longestCommonSubsequence(self, text1: str, text2: str) -> int: m = len(text1) n = len(text2) dp = [[0] * (n + 1) for _ in range(m + 1)] for i in range(1, m + 1): for j in range(1, n + 1): if text1[i -1] == text2[j - 1]: dp[i][j] = dp[i -1][j - 1] + 1 else: dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]) return dp[m][n]
http://www.jsqmd.com/news/659277/

相关文章:

  • Flutter 入门第八课:网络请求与数据解析(对接后端实战)
  • Abaqus Cohesive单元疲劳损伤的UMAT实现与工程验证
  • 【独家首曝】SITS2026未公开实验数据:传统RAG补全 vs. 新型Control-Code Modeling,响应延迟下降63%!
  • 不止于使能:用汇川PLC功能块封装,实现伺服轴状态管理与安全逻辑
  • 刚学编程不会debug?6个傻瓜式排查步骤,Python/Java/C通用,90%报错自己就能解决不用求人
  • 零基础上手DeepSeek-OCR-2:本地智能OCR工具保姆级部署教程
  • **图算法新视角:用Python实现最短路径的多种策略与性能对比**在现代软件开发中,**图算法**早已成为解决复杂问
  • IndexTTS-2-LLM快速入门:免费、本地化、高可用的语音合成解决方案
  • LFM2.5-1.2B-Thinking-GGUF从零开始:无Python环境依赖的纯二进制GGUF部署方案
  • 告别Word!用Cursor和MiKTeX打造你的专属LaTeX论文写作环境(附完整配置JSON)
  • 图像处理避坑指南:为什么你的Retinex算法总产生光晕?实测3种保边滤波方案
  • MacBook全盘格式化后如何通过联网恢复重装MacOS系统
  • mac codex intel版本
  • 如何生成ADDM报告_@addmrpt.sql自动数据库诊断监控工具
  • Display Driver Uninstaller技术解析:系统级驱动清理机制深度剖析
  • 实战Python逆向:从CRC32校验值反推隐藏数据
  • 8个效率神站 全免费 ,用过就回不去了
  • 2026建筑结构胶市场:这些企业以品质赢得口碑,建筑加固/建筑结构胶/建筑结构检测,建筑结构胶实力厂家选哪家 - 品牌推荐师
  • 告别手动整理!UDOP-large一键部署,英文文档智能分析原来这么简单
  • 别再死记硬背了!一张图帮你搞定C语言fopen所有打开模式(附Windows/Linux差异)
  • 多线程-案例-单例模式
  • 35 openclawCQRS模式应用:分离读写操作提升性能
  • 别再只跑Demo了!用MaixPy IDE给你的K210人脸识别项目加个‘本地数据库’(附完整代码)
  • 【优化求解】基于粒子群算法面向弹性提升的多种应急资源参与配电网抢修恢复附Matlab代码
  • Phi-3-mini-4k-instruct与LSTM模型结合:时序预测优化
  • 基于认知负荷理论的职场新人算法学习策略:如何循序渐进,避免挫败感。
  • 智能代码生成性能调优实战手册(企业级低延迟落地白皮书)
  • 【LangGraph】03-LangGraph之State
  • STM32H750项目实战:如何把DMA数据精准丢进512KB高速SRAM(Keil MDK配置详解)
  • Agent 的生命周期管理与治理