【算法一则】编辑距离 【动态规划】

题目

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

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

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

示例 1:输入:word1 = "horse", word2 = "ros"
输出:3
解释:
horse -> rorse (将 'h' 替换为 'r')
rorse -> rose (删除 'r')
rose -> ros (删除 'e')
示例 2:输入:word1 = "intention", word2 = "execution"
输出:5
解释:
intention -> inention (删除 't')
inention -> enention (将 'i' 替换为 'e')
enention -> exention (将 'n' 替换为 'x')
exention -> exection (将 'n' 替换为 'c')
exection -> execution (插入 'u')
提示:0 <= word1.length, word2.length <= 500
word1 和 word2 由小写英文字母组成

题解

这个问题可以使用动态规划来解决。我们可以定义一个二维数组dp,其中dp[i][j]表示将word1的前i个字符转换成word2的前j个字符所需的最少操作数。
在这里插入图片描述

首先,我们需要初始化dp数组的边界条件。当word1为空字符串时,要将其转换成word2的前j个字符,需要进行j次插入操作;同样地,当word2为空字符串时,要将word1的前i个字符转换成空字符串,需要进行i次删除操作。因此,我们可以初始化dp数组的第一行和第一列如下:

dp[0][j] = j,对于所有的0 <= j <= word2.length()
dp[i][0] = i,对于所有的0 <= i <= word1.length()

接下来,我们可以通过填充dp数组的其余部分来求解最少操作数。我们可以遍历word1和word2的所有字符,对于每一对字符word1[i-1]和word2[j-1],我们可以进行以下操作:

在这里插入图片描述

如果word1[i-1]等于word2[j-1],则不需要进行任何操作,dp[i][j] = dp[i-1][j-1];
如果word1[i-1]不等于word2[j-1],则可以进行插入、删除或替换操作。我们可以选择其中操作数最小的一种,即dp[i][j] = min(dp[i][j-1], dp[i-1][j], dp[i-1][j-1]) + 1;
最后,dp[word1.length()][word2.length()]即为将word1转换成word2所需的最少操作数。

代码

public int minDistance(String word1, String word2) {int n = word1.length();int m = word2.length();// dp[i][j] 表示 word1 的前 i 个字母和 word2 的前 j 个字母之间的编辑距离int[][] dp = new int[n + 1][m + 1];// base casefor (int i = 0; i <= n; i++) {dp[i][0] = i;}for (int j = 0; j <= m; j++) {dp[0][j] = j;}// 自底向上求解for (int i = 1; i <= n; i++) {char c1 = word1.charAt(i - 1);for (int j = 1; j <= m; j++) {char c2 = word2.charAt(j - 1);if (c1 == c2) { // 相同字符,不需要操作dp[i][j] = dp[i - 1][j - 1];} else { // 不同字符,取三种操作的最小值dp[i][j] = Math.min(Math.min(dp[i - 1][j], dp[i][j - 1]), dp[i - 1][j - 1]) + 1;}}}return dp[n][m];
}

总结

上面的提供了一种使用动态规划解决将一个单词转换成另一个单词所需的最少操作数的算法。以下是算法的主要步骤:

  • 初始化一个二维数组dp,其中dp[i][j]表示将word1的前i个字符转换成word2的前j个字符所需的最少操作数。
    ( 初始化dp数组的边界条件:当word1为空字符串时,要将其转换成word2的前j个字符,需要进行j次插入操作;当word2为空字符串时,要将word1的前i个字符转换成空字符串,需要进行i次删除操作。
  • 遍历word1和word2的所有字符,对于每一对字符word1[i-1]和word2[j-1]:
  • 如果word1[i-1]等于word2[j-1],则不需要进行任何操作,dp[i][j] = dp[i-1][j-1];
  • 如果word1[i-1]不等于word2[j-1],则可以进行插入、删除或替换操作。选择其中操作数最小的一种,即dp[i][j] = min(dp[i][j-1], dp[i-1][j], dp[i-1][j-1]) + 1。
  • 返回dp[word1.length()][word2.length()],即将word1转换成word2所需的最少操作数。
    这个算法的时间复杂度为O(m×n),其中m和n分别是word1和word2的长度。通过动态规划的思想,我们可以高效地求解这个问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/623288.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL学习笔记4——时间函数

MySQL时间函数 一、日期时间类型1、获取日期时间数据中部分信息的函数2、计算日期时间的函数3、其他日期时间函数 一、日期时间类型 时间函数就是用来处理时间的函数。时间&#xff0c;几乎可以说是各类项目中都会存在的数据&#xff0c;项目需求不同&#xff0c;我们需要的时…

CSS导读 (复合选择器 上)

&#xff08;大家好&#xff0c;今天我们将继续来学习CSS的相关知识&#xff0c;大家可以在评论区进行互动答疑哦~加油&#xff01;&#x1f495;&#xff09; 目录 二、CSS的复合选择器 2.1 什么是复合选择器 2.2 后代选择器(重要) 2.3 子选择器(重要) Questions 小提…

【数据可视化包Matplotlib】Matplotlib基本绘图方法

目录 一、Matplotlib绘图的基本流程&#xff08;一&#xff09;最简单的绘图&#xff08;仅指定y的值&#xff09;&#xff08;二&#xff09;更一般的绘图&#xff08;同时指定x和y的值&#xff09;&#xff08;三&#xff09;增加更多的绘图元素 二、布局相关的对象——Figur…

【XR806开发板试用】XR806在U8G2上增加MQTT+JSON控制

一、前言 U8G2移植参见之前写的文章 https://aijishu.com/a/1060000000292472本次增加MQTTJSON是站在大佬的肩膀上&#xff0c;参见 https://aijishu.com/a/1060000000284320CJSON的使用&#xff0c;参见 https://blog.csdn.net/fengxinlinux/article/details/53121287 二、成…

【C++类和对象】类和对象的引入

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

《二》Qt Creator工具介绍与使用

一、关于界面 点击文件--->新建文件或项目会出现如下图&#xff1a; 我们选择第一个 点击下一步下一步&#xff1a; 继续下一步直到结束&#xff1a; 二&#xff0c;具体文件介绍 我们点击pro查看以下 QT core gui第1行 表示使用qt的core和gui库&#xff0c;如果以后…

VScode配置C++环境进行运行和调试

文章目录 1、配置开发环境&#xff1a;即可以安装MinGW-w64&#xff08;Windows平台的一个gcc/g编译器&#xff09;2、在VScode中安装C/C插件3、VScode的编译和运行的配置4、VScode的调试的配置 1、配置开发环境&#xff1a;即可以安装MinGW-w64&#xff08;Windows平台的一个g…

计算机网络—TCP协议详解:协议构成、深度解析(1)

&#x1f3ac;慕斯主页&#xff1a;修仙—别有洞天 ♈️今日夜电波&#xff1a;マリンブルーの庭園—ずっと真夜中でいいのに。 0:34━━━━━━️&#x1f49f;──────── 3:34 &#x1f504; ◀️…

r3live 使用前提 雷达-相机外参标定 livox_camera_lidar_calibration

标定的是相机到雷达的,R3live下面配置的雷达到相机的,所以要把得到外参旋转矩阵求逆,再填入,平移矩阵则取负 港科大livox_camera_calib虽然操作方便&#xff0c;但是使用mid360雷达会有视角问题&#xff08;投影三维点到相机&#xff09;&#xff0c;尝试了很多场景&#xff0c…

群晖NAS安装Synology Office与Drive结合内网穿透实现本地文件公网分享与远程协作

文章目录 本教程解决的问题是&#xff1a;1. 本地环境配置2. 制作本地分享链接3. 制作公网访问链接4. 公网ip地址访问您的分享相册5. 制作固定公网访问链接 本教程解决的问题是&#xff1a; 1.Word&#xff0c;PPT&#xff0c;Excel等重要文件存在本地环境&#xff0c;如何在编…

如何用JAVA如何实现Word、Excel、PPT在线前端预览编辑的功能?

背景 随着信息化的发展&#xff0c;在线办公也日益成为了企业办公和个人学习不可或缺的一部分&#xff0c;作为微软Office的三大组成部分&#xff1a;Word、Excel和PPT也广泛应用于各种在线办公场景&#xff0c;但是由于浏览器限制及微软Office的不开源等特性&#xff0c;导致…

Ubuntu系统器怎么关闭防火墙?Ubuntu系统关闭防火墙命令

与许多Linux发行版&#xff0c;甚至Windows和 macOS 一样&#xff0c;Ubuntu系统也配备了防火墙。这是一项安全功能&#xff0c;可以阻止来自系统上不需要的源的连接。但有时&#xff0c;如果您想让所有网络流量通过&#xff0c;您可能需要禁用它。您甚至可能还想在防火墙上打开…