代码随想录算法训练营Day56|LC583 两个字符串的删除操作LC72 编辑距离

一句话总结:看起来复杂,动规分析以后就比较简单。

原题链接:583 两个字符串的删除操作

本质就是求两个字符串的最短子序列的长度。已经做过,不再详解。

class Solution {public int minDistance(String word1, String word2) {// dp数组找最长相同子序列长度,然后两字符串总长减去2 * 最长长度即可int m = word1.length(), n = word2.length();int[][] dp = new int[m + 1][n + 1];for (int i = 1; i <= m; ++i) {for (int j = 1; j <= n; ++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]);}}return m + n - dp[m][n] * 2;}
}

 原题链接:72 编辑距离

看起来比较难,用动规五部曲分析一下:

  1. 确定动规数组及其下标的含义: dp[i][j]表示以i - 1结尾的word1的子串到以j - 1结尾的word2的子串的最近的编辑距离;
  2. 确定状态转移方程:分为两种情况,当word1[i - 1] == word2[j - 1]时,显而易见的dp[i][j] = dp[i - 1][j - 1];当word1[i - 1] != word2[j - 1]时,最短的编辑距离又分为三种情况,首先是从删除word1[i - 1],此时dp[i][j] = dp[i - 1][j] + 1;然后是删除word2[j - 1],此时dp[i][j] = dp[i][j - 1] + 1;最后一种情况则是将word1[i - 1]替换为word2[j - 1]以使得两者相等,那么就有dp[i][j] = dp[i - 1][j - 1] + 1;在这三种情况中取最小值即可。即if (word1.charAt(i  -1) != word2.charAt(j - 1)) dp[i][j] = Math.min(Math.min(dp[i][j - 1] + 1, dp[i - 1][j] + 1), dp[i - 1][j - 1] + 1);
  3. dp数组的初始化:对于任意dp[i][0],编辑距离一定是删除完所有字符,因此dp[i][0] = i;同理dp[0][j] = j;
  4. dp数组的遍历顺序:从上面的递推方程可见依赖于i - 1和j - 1,因此从前往后即可;
  5. 举例推导:略。

最终代码如下:

class Solution {public int minDistance(String word1, String word2) {char[] cs1 = word1.toCharArray(), cs2 = word2.toCharArray();int m = word1.length(), n = word2.length();int[][] dp = new int[m + 1][n + 1];for (int i = 1; i <= m; ++i) {dp[i][0] = i;}for (int j = 1; j <= n; ++j) {dp[0][j] = j;}for (int i = 1; i <= m; ++i) {for (int j = 1; j <= n; ++j) {if (cs1[i - 1] == cs2[j - 1]) dp[i][j] = dp[i - 1][j - 1];else dp[i][j] = Math.min(dp[i][j - 1] + 1, Math.min(dp[i - 1][j] + 1, dp[i - 1][j - 1] + 1));}}return dp[m][n];}
}

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

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

相关文章

Day13-Java基础之运算符和表达式

运算符和表达式 运算符&#xff1a; 就是对常量或者变量进行操作的符号。 比如&#xff1a; - * / 表达式&#xff1a; 用运算符把常量或者变量连接起来的&#xff0c;符合Java语法的式子就是表达式。 比如&#xff1a;a b 这个整体就是表达式。 而其中是算术运算符的…

Python(11):网络编程

文章目录 一、一些基本概念二、软件的开发架构&#xff08;c/s架构和b/s架构&#xff09;三、OSI模型四、socket套接字编程1.socket编程过程2.python中的socket编程 一、一些基本概念 来了解一些网络的基本概念 名词解释IP&#xff08;互联网协议地址&#xff09;IP用来标识网…

【华为OD机试C++】统计字符

《最新华为OD机试题目带答案解析》:最新华为OD机试题目带答案解析,语言包括C、C++、Python、Java、JavaScript等。订阅专栏,获取专栏内所有文章阅读权限,持续同步更新! 文章目录 描述输入描述输出描述示例代码描述 输入一行字符,分别统计出包含英文字母、空格、数字和其它…

linux设置程序在开机时自启动

​常见的有三种方式&#xff1a;1、/etc/rc.local文件中添加自启动命令 对于某些没有使用systemd的Linux发行版&#xff0c;可以在/etc/rc.local文件中添加自启动命令。请确保该文件具有可执行权限。例如&#xff0c;在/etc/rc.local文件中添加以下内容&#xff1a; /…

PCB基础介绍

一&#xff0c;单层板&#xff1a; 1&#xff0c;铜皮 和导线类似&#xff0c;提供电路板上的电信号传导路径。 因为铜具有良好的导热性能&#xff0c;因此铜皮还可以用于散热。在高功率电子设备中&#xff0c;通过在PCB上增加铜皮面积和散热片&#xff0c;可以提高散热效果…

【洛谷题解】 P6995 [NEERC2014] Knockout Racing

分析 按照题意模拟即可。 我们只需要依次找到第 i i i&#xff08; 1 ≤ i ≤ N 1\le i\le N 1≤i≤N&#xff09;辆车在 t j t_j tj​ 时刻时所在的位置&#xff0c;看这个位置是不是在区间 [ x j , y j ] [x_j,y_j] [xj​,yj​] 之中&#xff0c;如果是&#xff0c;答案…

数字晶体管数字三极管

数字晶体管 指内部集成了电阻的三极管&#xff0c;有PNP和NPN型&#xff0c;也有双管&#xff0c;双管有3种形式&#xff0c;其中一种是PNPNPN。下面以双NPN示例&#xff0c;好处是外面没有电阻&#xff0c;批量应用时&#xff0c;焊点费用就可省下不少。双NPN的用在串口自动下…

Flutter知识点 --- key

Flutter 中的 Key 对象在Widget树的构建、更新和状态管理中扮演着重要角色。它主要用于帮助Flutter框架在Widget树发生变动时正确地识别和保留Widget的对应关系&#xff0c;以及在某些情况下维护状态。下面是Key的作用与原理的详细阐述&#xff1a; Key的作用 标识Widget的唯一…

开源相机管理库Aravis例程学习(二)——连续采集multiple-acquisition-main-thread

开源相机管理库Aravis例程学习&#xff08;二&#xff09;——连续采集multiple-acquisition-main-thread 简介例程代码函数说明arv_camera_set_acquisition_modearv_camera_create_streamarv_camera_get_payloadarv_buffer_newarv_stream_push_bufferarv_camera_start_acquisi…

目标检测YOLO实战应用案例100讲-基于轻量化神经网络的目标检测算法研究与应用(续)

目录 轻量化目标检测模型的参数量化 4.1引言 4.2模型量化的原理及过程 4.3实验结果及分析

如何看待2023年图灵奖

目录 1.概述 2.计算复杂性理论 3.随机性和伪随机性 4.学术生涯和领导力 1.概述 图灵奖&#xff08;Turing Award&#xff09;&#xff0c;全称A.M.图灵奖&#xff08;ACM A.M Turing Award&#xff09;&#xff0c;是由计算机领域的最高学术机构——美国计算机协会&#xf…

ElasticSearch 集群添加用户安全认证功能(设置访问密码)

前言 在6.8之前免费版本并不包含安全认证功能&#xff0c;之后版本有开放一些基础认证功能&#xff1b;为了防止各种事故&#xff0c;一般都会设置es集群的访问密码&#xff1b;但是在我尝试设置访问密码的时候发现&#xff0c;设置访问密码的前提必须要设置集群证书&#xff0…

java:多线程

多线程 在java程序中同时执行多个线程,每个线程独立执行不同的任务. 可以提高程序的性能和资源利用率,增加程序的并发性. 多线程的作用 1,提高程序性能 可以将一个任务分解成多个子任务并行处理,从而提高程序的运行速度 2,提高资源利用率 可以更好地利用CPU资源,提高CPU…

如何实现Windows RDP 远程桌面异地跨网连接

Windows RDP远程桌面的应用非常广泛。远程桌面协议(RDP)是一个多通道(multi-channel)的协议&#xff0c;让使用者(所在计算机称为用户端或本地计算机)连上提供微软终端机服务的计算机(称为服务端或远程计算机)。大部分的Windows版本都有用户端所需软件&#xff0c;有些其他操作…

Python Flask Web 框架-API接口开发_4

一、1、安装 Falsk 当前用户安装 pip3 install --user Flask 确认安装成功&#xff1a; 进入python交互模式看下Flask的介绍和版本&#xff1a; $ python3>>> import flask >>> print(flask.__doc__)flask~~~~~A microframework based on Werkzeug. Its …

病毒繁殖-第12届蓝桥杯选拔赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第52讲。 病毒繁殖&#xf…

Linux userdel命令教程:如何删除用户账户及其相关文件(附实例详解和注意事项)

Linux userdel命令介绍 userdel命令在Linux系统中用于删除用户账户及其相关文件。这个命令主要修改系统账户文件&#xff0c;删除所有引用到用户名的条目。 Linux userdel命令适用的Linux版本 userdel命令在大多数Linux发行版中都可以使用&#xff0c;包括但不限于Debian、U…

数据结构与算法——23.哈希冲突及其解决方法

这篇文章我们主要讲一下哈希冲突及其解决方法。 目录 1.哈希冲突的介绍 2.解决哈希冲突的方法 2.1 开放地址法 2.1.1 线性探测法 2.1.2 平方探测法&#xff08;二次探测法&#xff09; 2.2再哈希法 2.3链地址法 2.4建立公共溢出区 3.总结 1.哈希冲突的介绍 首先&…

静态路由

路由器主要功能是确定发送数据包的最佳路径以及将数据包从一个网络传送到另一个网络。路由是所有数据网络的核心所在&#xff0c;它通过搜索存储在路由表中的路由信息将数据包从源传送到目的地&#xff0c;所以说路由表是路由器工作的核心。路由器构建路由表的方式通常有3种:直…

vue快速入门(二十五)本地存储与初始化使用

注释很详细&#xff0c;直接上代码 上一篇 新增内容 本地获取数据数据存储到本地 源码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial…