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

【LeetCode 热题100】字符串 DP 三连:最长回文子串、最长公共子序列 编辑距离(力扣5 / 1143/ )(Go语言版)

✨ 字符串 DP 三连:最长回文子串、最长公共子序列 & 编辑距离(LeetCode 5 / 1143 / 72)

  • 🔁 5. 最长回文子串
  • 📏 1143. 最长公共子序列
  • ✂️ 72. 编辑距离

1️⃣ 最长回文子串(LeetCode 5)

📌 题目描述

给你一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。


🧠 解题思路:动态规划

✅ 状态定义

dp[i][j] 表示子串 s[i...j] 是否是回文串。

🔁 状态转移方程
  • 如果 s[i] == s[j]

    • j - i < 3,则 dp[i][j] = true
    • 否则:dp[i][j] = dp[i+1][j-1]
  • 否则:dp[i][j] = false


✅ Go 实现

func longestPalindrome(s string) string {n := len(s)if n < 2 {return s}dp := make([][]bool, n)for i := range dp {dp[i] = make([]bool, n)}maxLen := 1start := 0for r := 1; r < n; r++ {for l := 0; l < r; l++ {if s[l] == s[r] {if r - l < 3 {dp[l][r] = true} else {dp[l][r] = dp[l+1][r-1]}}if dp[l][r] && r - l + 1 > maxLen {maxLen = r - l + 1start = l}}}return s[start:start+maxLen]
}

2️⃣ 最长公共子序列(LeetCode 1143)

📌 题目描述

给定两个字符串 text1text2,返回它们的最长公共子序列的长度。


🧠 解题思路:二维 DP

✅ 状态定义

dp[i][j] 表示 text1[0...i-1]text2[0...j-1] 的最长公共子序列长度。

🔁 状态转移
  • 如果 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])

✅ Go 实现

func longestCommonSubsequence(text1 string, text2 string) int {m, n := len(text1), len(text2)dp := make([][]int, m+1)for i := range dp {dp[i] = make([]int, n+1)}for i := 1; i <= m; i++ {for j := 1; j <= n; j++ {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]
}func max(a, b int) int {if a > b {return a}return b
}

3️⃣ 编辑距离(LeetCode 72)

📌 题目描述

给你两个单词 word1word2,请返回将 word1 转换成 word2 所使用的最少操作数(插入、删除、替换)。


🧠 解题思路:经典 DP 模板题

✅ 状态定义

dp[i][j] 表示将 word1[0...i-1] 转换为 word2[0...j-1] 所需的最小编辑距离。

🔁 状态转移
  • 如果 word1[i-1] == word2[j-1],则 dp[i][j] = dp[i-1][j-1]

  • 否则取三种操作的最小值加 1:

    • 插入:dp[i][j-1] + 1
    • 删除:dp[i-1][j] + 1
    • 替换:dp[i-1][j-1] + 1

✅ Go 实现

func minDistance(word1 string, word2 string) int {m, n := len(word1), len(word2)dp := make([][]int, m+1)for i := range dp {dp[i] = make([]int, n+1)}for i := 0; i <= m; i++ {dp[i][0] = i}for j := 0; j <= n; j++ {dp[0][j] = j}for i := 1; i <= m; i++ {for j := 1; j <= n; j++ {if word1[i-1] == word2[j-1] {dp[i][j] = dp[i-1][j-1]} else {dp[i][j] = min(dp[i-1][j-1], // 替换dp[i][j-1],   // 插入dp[i-1][j],   // 删除) + 1}}}return dp[m][n]
}func min(a, b, c int) int {if a < b {if a < c {return a}return c}if b < c {return b}return c
}

✅ 总结对比

题目类型状态定义状态转移重点
5 最长回文子串判断子串是否回文dp[i][j] 是不是回文s[i]==s[j] && dp[i+1][j-1]需倒序遍历
1143 最长公共子序列序列匹配dp[i][j] 表示最长长度相等加一,否则取较大不能连续字符
72 编辑距离转换操作dp[i][j] 表示最小操作数插入/删除/替换 三选一是经典题!

http://www.xdnf.cn/news/937837.html

相关文章:

  • 【P2P】低延迟直播(尤其是 P2P 实时分发)常用的 x264 编码参数示例
  • Prompt工程学习之自我一致性
  • 6.8 note
  • Python学习——排序
  • Linux 内存管理调试分析:ftrace、perf、crash 的系统化使用
  • 3.机器学习-分类模型-线性模型
  • 《深入理解 Nacos 集群与 Raft 协议》系列四:日志复制机制:Raft 如何确保提交可靠且幂等
  • 《Spring Boot 微服务架构下的高并发活动系统设计与实践》
  • CQF预备知识:Python相关库 -- SciPy 安装
  • 会计-合并-5- 处置交易在合报与个报会计处理
  • 由汇编代码确定switch语句
  • 第13次01:广告及商品数据呈现
  • (LeetCode 每日一题)386. 字典序排数(递归、深度优先搜索dfs || 递推)
  • 动态生成 PV 的机制:使用 NFS-Client Provisione
  • 深入解析Golang反射机制与高效文件操作实践
  • TCP相关问题 第一篇
  • Windows权限提升篇数据库篇MYSQLMSSQLORACLE自动化项目
  • 管理数据洪流:自动化处理与归档每日数据文件的策略与实践
  • BOM(Browser Object Model)核心对象手册
  • CNN核心机制深度解析:卷积池化原理 PyTorch实现经典网络
  • MSYS2 环境配置与 Python 项目依赖管理笔记
  • Z-FOLD: A Frustratingly Easy Post-Training Quantization Scheme for LLMs
  • MS39531N 是一款正弦驱动的三相无感直流电机驱动器,具有最小振动和高效率的特点
  • 深入理解 Java 的反射、注解与动态代理
  • 基于Python学习《Head First设计模式》第十章 状态模式
  • JavaScript数组扁平化(Array Flattening)全解析:从基础到进阶的9种实现方式及深度对比
  • C++.OpenGL (17/64)深度测试(Depth Testing)
  • Python Wheel 打包基本原理详解
  • LangChain工具集成实战:构建智能问答系统完整指南
  • RoboDK 自定义机器人