leetcode712. 两个字符串的最小ASCII删除和(最短非公共子序列)

该博客介绍了LeetCode 712题目的解决方法,探讨了如何找到使两个字符串相等所需的最小ASCII字符删除和。通过动态规划的两种不同实现方式——加冗余字符和不加冗余字符,分析了如何计算字符串匹配过程中的最小删除总和,并指出第三种情况可以被前两种情况覆盖,因此不需要单独考虑。
摘要由CSDN通过智能技术生成

传送门

题目:给定两个字符串s1, s2,找到使两个字符串相等所需删除字符的ASCII值的最小和。
输入: s1 = “sea”, s2 = “eat”
输出: 231
解释: 在 “sea” 中删除 “s” 并将 “s” 的值(115)加入总和。
在 “eat” 中删除 “t” 并将 116 加入总和。
结束时,两个字符串相等,115 + 116 = 231 就是符合条件的最小和

和1143题求的是互补的序列

动态过程中有三种状态(这里没有在字符串前加冗余字符,所以dp[i]比较的是字符s[i-1])

1.s1[i-1] == s2[j-1],新增的两个字符相等的情况下没有必要删除之前的结果,因此dp[i][j] = dp[i-1][j-1]

2.s1[i-1] != s2[j-1],取三者的最小值
(1)保留s2串,删除s1串的字符,dp[i][j] = dp[i-1][j] + s1.charAt(i-1)
(2)保留s1串,删除s2串的字符,dp[i][j] = dp[i][j-1] + s1.charAt(j-1)
(3)删除s1、s2串的字符,dp[i][j] = dp[i-1][j-1] + s1.charAt(i-1) + s2.charAt(j-1)

但是第三中情况会被包含在1或者2里,可以不写到dp里

1.加冗余字符的写法(dp[i][j]就对应的s1[i] s2[j])
 	public int minimumDeleteSum(String s1, String s2) {
   
        s1 = 'a' + s1; // 两个字符串前面加上冗余字符,dp[i][j]就比较的是字符s1[i],s2[j]
        s2 = 'a' + s2;
        int[][] dp = new int[s1.length()][s2.length()];
         
         // 注意:要初始化dp[0][j]和dp[i][0],这个初始化就算没有加冗余也要做的
         // 因为下面方程用到了dp[0][j] 和dp[i][0]
        for (int i = 1; i < s1.length(); ++i) {
     
            dp[i][0] = dp[i - 1][0] + s1.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值