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

建设工程的招标网站有哪些百度指数数据

建设工程的招标网站有哪些,百度指数数据,网络设计报告范文,班级网站源码✨ 字符串 DP 三连:最长回文子串、最长公共子序列 & 编辑距离(LeetCode 5 / 1143 / 72) 🔁 5. 最长回文子串📏 1143. 最长公共子序列✂️ 72. 编辑距离 1️⃣ 最长回文子串(LeetCode 5) &…

✨ 字符串 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.dtcms.com/wzjs/305913.html

相关文章:

  • 网页设计与网站建设教学视频百度推广时间段在哪里设置
  • 用dw做网站怎么单独修改字体营销策划公司介绍
  • 房屋建设网站7个湖北seo网站推广策略
  • 网站域名备案号查询seo1现在怎么看不了
  • 什么网站做顶置便宜百度热搜关键词排行榜
  • 如何做网站卖产品全网营销是什么意思
  • 甘肃手机网站建设优质友情链接
  • 网站制作的设备环境互联网营销工具有哪些
  • 道路建设网站专题优秀网站网页设计图片
  • 做街舞网站的素材现在做网络推广好做吗
  • 网上花店 网站源代码网址浏览大全
  • 政府与机构类网站廊坊seo管理
  • 网站怎么做跳转怎么申请网站详细步骤
  • 网站生成海报功能怎么做免费下载百度并安装
  • 苏州网站制作网络建设公司关键词查找
  • 甘肃企业网站建设百度搜索关键词排名靠前
  • 做公众号app 网站 app接广告推广的平台
  • 眉山网站推广百度电脑网页版入口
  • 外围网站怎么做营销方案模板
  • 委托完成网站建设合同模板培训机构查询网
  • 山东滨州疫情最新消息seo服务运用什么技术
  • 网站插件开发vue seo优化
  • 化州网站建设培训机构退费纠纷一般怎么解决
  • 青海wap网站建设站长之家seo工具
  • 网站建设需要哪些资质网络优化工程师是做什么的
  • 政府网站建设方案搜索关键词排名优化软件
  • 网站的注册和登录界面怎么做阿里云域名查询和注册
  • 河南省网站制作公司南昌seo代理商
  • 志愿服务网站建设方案百度推广北京总部电话
  • 高校网站建设的优势和不足我在百度下的订单如何查询