首页 > 其他分享 >【博学谷学习记录】超强总结,用心分享 | 动态规划经典例题总结三

【博学谷学习记录】超强总结,用心分享 | 动态规划经典例题总结三

时间:2022-12-22 10:35:20浏览次数:40  
标签:总结 int 超强 word1 word2 字符串 操作 例题 dp

题目

给你两个单词 word1word2请返回将 word1 转换成 word2 所使用的最少操作数

你可以对一个单词进行如下三种操作:

  • 插入一个字符
  • 删除一个字符
  • 替换一个字符

提示:

  • 0 <= word1.length, word2.length <= 500
  • word1word2 由小写英文字母组成

解题思路

一、定义数组元素的含义

由于我们的目的求将 word1 转换成 word2 所使用的最少操作数 。那我们就定义 dp[i] [j]的含义为:当字符串

word1 的长度为 i,字符串 word2 的长度为 j 时,将 word1 转化为 word2 所使用的最少操作次数为 dp[i] [j]。

二、找出关系数组元素间的关系式

接下来我们就要找 dp[i] [j] 元素之间的关系了,比起其他题,这道题相对比较难找一点,但是,不管多难找,大部

分情况下,dp[i] [j] 和 dp[i-1] [j]、dp[i] [j-1]、dp[i-1] [j-1] 肯定存在某种关系。因为我们的目标就是,从规模小

的,通过一些操作,推导出规模大的。对于这道题,我们可以对 word1 进行三种操作

由于我们是要让操作的次数最小,所以我们要寻找最佳操作。那么有如下关系式:

一、如果我们 word1[i] 与 word2 [j] 相等,这个时候不需要进行任何操作,显然有 dp[i] [j] = dp[i-1] [j-1]。(别忘了 dp[i] [j] 的含义哈)。

二、如果我们 word1[i] 与 word2 [j] 不相等,这个时候我们就必须进行调整,而调整的操作有 3 种,我们要选择

一种。三种操作对应的关系试如下(注意字符串与字符的区别):

  1. 如果把字符 word1[i] 替换成与 word2[j] 相等,则有 dp[i] [j] = dp[i-1] [j-1] + 1;
  2. 如果在字符串 word1末尾插入一个与 word2[j] 相等的字符,则有 dp[i] [j] = dp[i] [j-1] + 1;
  3. 如果把字符 word1[i] 删除,则有 dp[i] [j] = dp[i-1] [j] + 1;

那么我们应该选择一种操作,使得 dp[i] [j] 的值最小,显然有

dp[i] [j] = min(dp[i-1] [j-1],dp[i] [j-1],dp[[i-1] [j]]) + 1;

三、找出初始值

当 dp[i] [j] 中,如果 i 或者 j 有一个为 0,那么还能使用关系式吗?答是不能的,因为这个时候把 i - 1 或者 j - 1,就变成负数了,数组就会出问题了,所以我们的初始值是计算出所有的 dp[0] [0….n] 和所有的 dp[0….m] [0]。这个还是非常容易计算的,因为当有一个字符串的长度为 0 时,转化为另外一个字符串,那就只能一直进行插入或者删除操作了。

一个空串和一个非空串的编辑距离为 dp[i][0] = i 和 dp[0][j] = j,dp[i][0] 相当于对 word1 执行 i 次删除操作,dp[0][j] 相当于对 word1执行 j 次插入操作。


代码

public int minDistance(String word1, String word2) {
    int n = word1.length();
    int m = word2.length();

    // 有一个字符串为空串的情况
    if (n * m == 0) {
        return n + m;
    }

    // dp数组
    int[][] dp = new int[n + 1][m + 1];

    // 边界状态初始化
    for (int i = 0; i < n + 1; i++) {
        dp[i][0] = i;
    }
    for (int j = 0; j < m + 1; j++) {
        dp[0][j] = j;
    }

    // 计算所有 dp 值
    for (int i = 1; i < n + 1; i++) {
        for (int j = 1; j < m + 1; j++) {
            int left = dp[i - 1][j] + 1;
            int down = dp[i][j - 1] + 1;
            int left_down = dp[i - 1][j - 1];
            if (word1.charAt(i - 1) != word2.charAt(j - 1)) {
                left_down += 1;
            }
            dp[i][j] = Math.min(left, Math.min(down, left_down));
        }
    }
    return dp[n][m];
}

标签:总结,int,超强,word1,word2,字符串,操作,例题,dp
From: https://www.cnblogs.com/Azureblue/p/16997830.html

相关文章

  • 【博学谷学习记录】超强总结,用心分享 | 动态规划经典例题总结二
    打家劫舍Ⅰ题目你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在......
  • 【博学谷学习记录】超强总结,用心分享 | 动态规划经典例题总结一
    不同路径Ⅰ题目一个机器人位于一个mxn网格的左上角(起始点在下图中标记为“Start”)。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中......
  • 工作5年的老程序员的年终总结
    看了上篇的博客是2020年9月10号,已经两年多没写博客了,重新执笔开始写篇年终总结!时间飞逝,已经毕业5年多,这一路经历太多了,这篇博客对整个经历进行复盘和总结。......
  • 冲刺总结(七)
    冲刺总结(七)一、登录注册这里注册用户lcy1211,密码设置为123456来到数据库,我们可以看到刚刚注册的用户lcy1211,和通过密态储存的口令123456二、加解密本项目在kali......
  • 12月21日内容总结——forms组件渲染标签、展示信息、校验数据的一些补充,forms组件参数
    目录一、forms组件渲染标签二、forms组件展示信息三、forms组件校验补充四、forms组件参数补充五、forms组件源码剖析六、modelform组件什么是modelform组件?使用校验性组件......
  • Pandas中高效的选择和替换操作总结
    使用正确的工具和技术来最大限度地利用数据是很重要的。Pandas是数据操作、分析和可视化的重要工具,有效地使用Pandas可能具有挑战性,从使用向量化操作到利用内置函数,这些最佳......
  • Express框架总结
    express框架总结Express安装通过express提供的脚手架直接创建一个应用安装脚手架:npminstall-gexpress-generator创建项目:expressexpress-demo安装依赖:npmi......
  • TI工程师总结的判断ADS129x是否工作正常的方法步骤
    当大多数ADC出现无响应时,可以通过一些基本的调试技术帮助验证器件是否仍然正常工作。以下是ADS129x器件出现无响应时需要采取的一些基本步骤:为器件通电。然后探测器......
  • 2022年总结
    转眼,2022年就剩下十多天了。 倒是应了那句老话:“人生天地之间,若白驹过隙,忽然而已。” 不管你是否准备好,2022年倒计时的钟表已经敲响,最后十天,请记得好好地谢谢自己!......
  • “互帮互助”小程序开发总结
    这次小程序开发的经历让我学到了很多,下面我就将一一总结我从中学到的知识1.我学会了规范的编程。以前的我不懂编程规范,编出来的代码既不写注释,阅读性又很差,而且变量名大部......