代码随想录训练营day56, 两个字符串的删除操作, 编辑字符
admin
2024-03-24 00:32:50
0

两个字符串的删除操作

动态规划1

  1. 数组含义: 以i-1为结尾的字符串word1,和以j-1位结尾的字符串word2,想要达到相等,所需要删除元素的最少次数

  2. 递推公式:

    1. 当两个不相等(有三种情况)

      1. 删word[i-1], 操作次数为dp[i-1][j] + 1
      2. 删word[j-1], 操作次数为dp[i][j-1] + 1
      3. 同时删两个, 操作次数为dp[i-1][j-1] + 2 (dp[i-1][j-1] + 1等于上面either, 可忽略)

      (最后当然是取最小值)

  3. 初始化: 当一个字符串是空的时, 需要几步才能变成相同的呢, 答案是i或者j

class Solution {public int minDistance(String word1, String word2) {//动规一, 通过取删除操作的最小值int len1 = word1.length();int len2 = word2.length();int[][] dp = new int[len1 + 1][len2 + 2];//初始化, 都是i//这里是<=, 因为要让数组正好等于string长度for(int i = 0; i <= len1; i++){dp[i][0] = i;}for(int j = 0; j <= len2; j++){dp[0][j] = j;}//开始遍历for(int i = 1; i <= len1; i++){for(int j = 1; j <= len2; j++){//如果相等的话又不用操作if(word1.charAt(i - 1) == word2.charAt(j - 1)){dp[i][j] = dp[i - 1][j - 1];} else {//不相等, 要么删i要么删j, 最小值dp[i][j] = Math.min(dp[i - 1][j] + 1, dp[i][j - 1] + 1);}}}return dp[len1][len2];}
}

动态规划2:

本题基础上和LC1143(最长公共子序列)是有点相似的, 只需要算出总共相同的字母长度, 然后全部的减去这个值就行了

class Solution {public int minDistance(String word1, String word2) {int len1 = word1.length();int len2 = word2.length();int[][] dp = new int[len1 + 1][len2 + 1];//这个版本的话先求最长公共子序列, 初始值必然是0for(int i = 1; i <= len1; i++){for(int j = 1; j <= len2; j++){if(word1.charAt(i-1) == word2.charAt(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]);}}}//最后算出来的是长度, 所以两个加起来减去长度*2return len1 + len2 - dp[len1][len2]*2;}
}

编辑字符

给你两个word, 请计算出将word1转换成word2所使用的最小操作数(上一题只需要删除, 这里可以进行插入, 删除, 和替换)

仍然还是经典五部曲:

  1. 数组定义: 以i-1和j-1为结尾的数据,最近编辑距离为dp[i][j]
  2. 递推公式: 有四种操作: 不操作,增, 删, 改
    1. 如果word相等, 说明不用编辑, 那么就是dp[i-1][j-1]
    2. 如果不相等, 此时就要编辑栏
      1. 删除: word1或者word2删除一个元素, 次数加一: dp[i][j-1]+1/dp[i-1][j]+1
      2. 增加: 其实可以发现, 增加一个元素就是相当于另一个word减少一个元素
      3. 替换: 可以理解为两个都退一步, dp[i-1][j-1] + 1
  3. 初始化: 这里和上一题一样 ,默认为i
class Solution {public int minDistance(String word1, String word2) {int len1 = word1.length();int len2 = word2.length();int[][] dp = new int[len1 + 1][len2 + 1];for(int i = 0; i <= len1; i++){dp[i][0] = i;}for(int j = 0; j <= len2; j++){dp[0][j] = j;}for(int i = 1; i <= len1; i++){for(int j = 1; j <= len2; j++){if(word1.charAt(i - 1) == word2.charAt(j - 1)){//相等则不做任何操作dp[i][j] = dp[i - 1][j - 1];} else {//不相等则做, 删除和替换的操作dp[i][j] = Math.min(Math.min(dp[i-1][j] + 1, dp[i][j-1] + 1),dp[i-1][j-1] + 1);}}}return dp[len1][len2];}
}

相关内容

热门资讯

贷款也“拼团” 银行抢单忙 购物能“拼团”,贷款也能! 近日,一场“拼团融资”的银企对接活动在省工业和信息化厅拉开帷幕。 “贷款...
逛花展、赶市集、嗨直播!202... 5月23日 “2026北京直播电商购物月” 在丰台区丽泽金融商务区·2026北京国际花展 正式拉开帷...
2026中关村毕业季|AI“吃... “上帝会掷骰子吗?” 在联想未来中心的“与智者同场”展区,一位海淀学子对着屏幕问道。 爱因斯坦微微前...
原创 今... 今日为5月23日,国际现货黄金价格在4500美元/盎司整数关口附近徘徊不前,日内最低触及4480美元...
三连亏后变为“无主”状态,农尚... 从吴亮手中接盘农尚环境(300536)不足三年后,林峰如今让出了公司控制权,上市公司进入“无主”状态...
55岁湖南女首富出手!豪掷13... 快科技5月24日消息,与马斯克、库克并肩而坐,刚参加完国宴的湖南女首富周群飞就买了家上市企业。 近日...
外资加仓A股,岂是跟风这么简单... 熬过忙碌的交易日,在周末安静时段,理清接下来布局方向。本篇为大家准备了5条要闻,涵盖市场动态、行业变...
原创 俄... 在全球能源的残酷牌桌上,手里攥着石油,腰杆子才能硬气。长期以来,中东的沙漠、俄罗斯的冰原、美国的页岩...
喜力啤酒有产品将涨价,华润啤酒... 来源:红星新闻 红星资本局5月22日消息,今日,红星资本局从雪花啤酒(厦门)有限公司、华润啤酒方面获...
原创 金... 心理预期调整刻不容缓,五月二十二日,黄金价格或将重现十五年前的历史性低迷。 近期若您密切关注着黄金市...
原创 马... 埃隆·马斯克如果能让SpaceX实现“科幻小说”级别的目标,他可能获得1万亿美元的收入。 埃隆·马斯...
涨涨涨!放开限制、可加杠杆!这... 韩国股市站在风口上! 据最新消息,为吸引更多海外资金进入股市,韩国政府计划放开限制,允许境外投资者直...
下周9家上会丨科创板首单IPO... IPO及再融资上会预告 据交易所官网审核动态信息,下周(5.25-5.29)IPO上会审核6家企业,...
富途、老虎市值蒸发1/4!或被... 来源:金融时报 5月22日,中国证监会宣布依法对Tiger Brokers (NZ) Limited...
马爸爸的好兄弟钱多多搞了杀猪盘... *此图由AI生成 作者| 史大郎&猫哥 来源| 是史大郎&大猫财经Pro 上周四,港股经纬天地大崩盘...
原创 壳... 编辑:XL 国际能源圈最近炸开了锅,壳牌这家百年石油巨头在2026年3月与委内瑞拉政府正式签署多项油...
存储热潮愈演愈烈!奖金拿到手软... 财联社5月24日讯(编辑 卞纯)在席卷全球的存储芯片热潮中,韩国“存储芯片双雄”SK海力士和三星无疑...
揽牌、合作、生态,跨境支付头部... 近日,国内头部跨境支付机构密集落地海外重要布局,一方面,连连数字、PingPong两家公司相继在中东...
原创 帮... 老铁们,周末好!我是帮主郑重。刚扫了一眼下周的财经日历,好家伙,事件一个接一个,堪称“消息面轰炸周”...
海南省住建厅与中国石化海南石油... 5月22日,中国石化海南石油分公司代表、党委书记李新强、总经理蔡文东一行赴海南省住建厅拜访交流。省住...