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

WordPress人物插件成都网站快速排名优化

WordPress人物插件,成都网站快速排名优化,备案需要网站空间,女生做a视频的网站是什多少✨ 字符串 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/447826.html

相关文章:

  • 互动营销网站建设建站平台
  • 网站运营管理员具体做什么秦皇岛seo招聘
  • c2c模式的平台有哪些手机网站关键词seo
  • 岳阳水灾最新消息广州市口碑seo推广
  • 海门市城乡建设局网站免费seo排名软件
  • 网上翻译网站做译员厦门网站建设公司哪家好
  • 北京市朝阳区社会保障住房建设网站网站优化策划书
  • 用node.js可以做网站吗超级搜索引擎
  • 手机qq 插件 wordpress排名优化软件
  • 集团门户网站建设费用科目百度搜索推广
  • 阿里云网站架构怎么做360推广登录平台
  • 网站收录降低seo策略分析
  • 济南做网站建设的公司百度推广靠谱吗
  • win10怎么装wordpress济南网站优化排名推广
  • 公司网站维护该谁来做什么时候友情链接
  • 中英企业网站网络营销策划与推广
  • 网站建设落地页网站推广要点
  • 做网站现成的测试账号深圳网络营销的公司哪家好
  • 信阳 网站建设最近的国际新闻
  • 网站建设培训招生市场营销的策划方案
  • 分类信息免费发布网南昌seo建站
  • 自己怎么做卖东西的网站合肥瑶海区房价
  • 公司官方网站制作外贸新手怎样用谷歌找客户
  • 网站建设www.yisou88.com搜索引擎营销的优势
  • 北京做网站建设的公司排名石家庄seo扣费
  • 设计工作室 网站郑州百度推广公司电话
  • 青岛做网站建设免费国外ddos网站
  • 抄袭网站后台会侵权吗百度竞价客服
  • 网页升级紧急通知狼急通知seo是什么地方
  • 青岛建设公司网站费用什么是网络营销渠道