LeetCode72:编辑距离

题目链接:72. 编辑距离 - 力扣(LeetCode)

代码如下:

class Solution {
public:int minDistance(string word1, string word2) {vector<vector<int> > dp(word1.size() + 1, vector<int>(word2.size() + 1));for(int i = 0; i <= word1.size(); i++)  dp[i][0] = i;for(int j = 0; j <= word2.size(); j++)  dp[0][j] = j;for(int i = 1; i <= word1.size(); i++){for(int j = 1; j <= word2.size(); j++){if(word1[i - 1] == word2[j - 1]){dp[i][j] = dp[i - 1][j - 1];}else{dp[i][j] = min(min(dp[i - 1][j] + 1, dp[i][j - 1] + 1), dp[i - 1][j - 1] + 1);}}}return dp[word1.size()][word2.size()];}
};

dp的含义:以i-1为结尾的word1和以j-1为结尾的word2使这两个相同的最小操作次数

这个i-1和j-1仍然是为了方便初始化。

dp的递推公式:

if(word1[i - 1] == word2[j - 1])
{
           dp[i][j] = dp[i - 1][j - 1];
}
else
{
          dp[i][j] = min(min(dp[i - 1][j] + 1, dp[i][j - 1] + 1), dp[i - 1][j - 1] + 1);
}

在这个之前我们先知道,如果word1删除一个元素,是不是和word2添加一个元素的效果是一样的。

如果word1[i - 1]等于word2[i - 1]的话,word1删除,也就是dp[i - 1][j] + 1,然后就是word1添加元素,其实word1添加元素,那么是不是和word2删除元素是一样的,这个时候那么我们就直接转换成dp[i][j - 1] + 1就可以了,因为dp的j列其实也就是word2字符串长度的大小。在一个就是替换,这个替换的话,就需要dp[i - 1][j - 1] + 1,因为替换完变成一样的了,那么就需要再加一步操作就好,这个时候的长度是不会改变的。然后取最小的值就好。

初始化:

这个时候我们需要初始化这两个dp[i][0]和dp[0][j],这个就需要数值了,因为需要初始化数值才能往后进行推到

遍历顺序:

这个题目还是一样,由左到右,由上到下就可以了,所以这个题目我们就正常遍历就好了。

返回值:这个我们返回的仍然是两个字符串的长度即可。

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

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

相关文章

复现第一周24

1.[SWPUCTF 2021 新生赛]gift_F12 1&#xff09;打开题目 2&#xff09;看源码 3&#xff09;直接ctrl&#xff0b;f搜索flag 2.[SWPUCTF 2021 新生赛]nc签到 1&#xff09;开题 2&#xff09;下载附件用记事本打开 3&#xff09;打开kali使用nc连接代码 输入l\s命令绕过黑名…

LSTM,全称长短期记忆网络(Long Short-Term Memory),是一种特殊的循环神经网络(RNN)结构

关于lstm超参数设置&#xff0c;每个参数都有合适的范围&#xff0c;超过这个范围则lstm训练不再有效&#xff0c;loss不变&#xff0c;acc也不变 LSTM&#xff0c;全称长短期记忆网络&#xff08;Long Short-Term Memory&#xff09;&#xff0c;是一种特殊的循环神经网络&am…

「Mac畅玩鸿蒙与硬件8」鸿蒙开发环境配置篇8 - 应用依赖与资源管理

本篇将介绍如何在 HarmonyOS 项目中高效管理资源文件和依赖&#xff0c;以确保代码结构清晰并提升应用性能。资源管理涉及图片、字符串、多语言文件等&#xff0c;通过优化文件加载和依赖管理&#xff0c;可以显著提升项目的加载速度和运行效率。 关键词 资源管理应用依赖优化…

15分钟学 Go 小项目:Web API

Web API 在现代应用开发中&#xff0c;Web API&#xff08;应用程序编程接口&#xff09;是实现系统间交互的关键。通过理解HTTP协议、路由、RESTful设计原则&#xff0c;我们可以设计出高效、可维护的API。接下来&#xff0c;我们将深入探讨这些主题&#xff0c;并以一个简单…

Android SDK Version 33: ActivityCompat.requestPermissions不弹框

文章目录 异常现象原因 异常现象 使用Android进行权限判断时&#xff0c;ActivityCompat.requestPermissions不弹框。API为33 原因 从API33开始&#xff0c;为了优化用户体验&#xff0c;只有App全部加载完成并可用后&#xff0c;才会弹授权框。也就说&#xff0c;不能在onC…

软件评测第二期

《遥远的救世主》&#xff0c;自己得想办法&#xff0c;不断地救赎自己了&#xff0c;同时开源竞争&#xff0c;开源竞争&#xff08;自己没有办法完全掌握技术的时候就开源掉&#xff0c;培养出更多的技术依赖&#xff0c;让更多人完善你的技术&#xff0c;那么这不就是在砸罐…

查找算法简记

一、简单查找&#xff08;顺序查找&#xff09; 最基本的查找&#xff0c;相当于遍历&#xff0c;从头到尾一个一个找。 二、二分查找 1、简述 二分查找的输入是一个有序的元素列表。 如果要查找的元素包含在列表中&#xff0c;二分查找返回其位置&#xff1b; 否则返回null。…

开发流程初学者指南——需求分析

目录 从零开始理解需求分析什么是需求分析&#xff1f;需求分析的目标需求分析的基本原则需求分析的各个阶段需求分析的常用方法和工具编写需求文档总结 从零开始理解需求分析 需求分析是软件开发过程中不可或缺的一环&#xff0c;它帮助我们明确用户的需求&#xff0c;确保最…

大模型,多模态大模型面试【LoRA,分类,动静态数据类型,DDPM,ControlNet,IP-Adapter, Stable Diffusion】

大模型&#xff0c;多模态大模型面试【LoRA&#xff0c;分类&#xff0c;动静态数据类型&#xff0c;DDPM&#xff0c;ControlNet&#xff0c;IP-Adapter, Stable Diffusion】 问题一&#xff1a;LoRA是用在节省资源的场景下&#xff0c;那么LoRA具体是节省了内存带宽还是显存呢…

数据结构之链式结构二叉树的实现(进阶版)

本篇文章主要讲解链式二叉树的层序遍历以及判断是否为一棵完全二叉树 二者将会用到之前学过的队列知识&#xff0c;是将队列和二叉树的整合 一、如何将之前已经写好的文件加入当前的编译界面 如图所示&#xff0c;打开我们需要加入文件所在的文件夹&#xff0c;找到我们要加…

StructRAG简介

StructRAG是一种新型的框架&#xff0c;旨在提升大型语言模型&#xff08;LLMs&#xff09;在知识密集型推理任务中的性能。它通过推理时的混合信息结构化机制&#xff0c;根据任务需求以最合适的格式构建和利用结构化知识。 以下是StructRAG的核心组成部分和工作流程&#xff…

Windows Server NTFS磁盘变RAM的处理过程

问题描述 客户服务器的磁盘数据爆满&#xff0c;需要将磁盘进行扩容&#xff0c;因为是虚拟机所以先在虚拟化平台上将原来的磁盘空间改大&#xff0c;再进入系统&#xff0c;在磁盘管理器上将需要扩容的磁盘进行扩展。扩展完后系统报文件系统有问题&#xff0c;扩容的磁盘容量…

LLaMA Factory 核心原理讲解

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于大模型算法的研究与应用。曾担任百度千帆大模型比赛、BPAA算法大赛评委,编写微软OpenAI考试认证指导手册。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。授权多项发明专利。对机器学…

如何让反向代购客户享受丝滑般的下单之旅?

想象一下&#xff0c;一键下单&#xff0c;轻松购物&#xff0c;仿佛穿越时空的魔法&#xff0c;让中国好货瞬间触手可及&#xff01;从made in china的美妆神器到潮流服饰&#xff0c;从尖端数码产品到温馨家居用品&#xff0c;从令人垂涎的美食到贴心的母婴用品&#xff0c;这…

解决Selenium的3大痛点!这款工具让你的自动化测试效率翻倍!

相信使用过Selenium WebDriver的小伙伴对其最大的诟病有3点&#xff0c;一是浏览器的driver和版本对应问题&#xff0c;第二是Selenium的执行速度&#xff0c;最后一个槽点是对页面元素文本值的断言非常不便。 在我们长期维护大量UI自动化测试用例的过程中这些痛点会让我们耗费…

UI设计公司—兰亭妙微—提供优秀的医疗行业UI设计

医疗行业界面解决方案以医患使用者为中心&#xff0c;遵循行业使用习惯和表达方式&#xff0c;优化使用流程、设计简洁、人性化的操作界面&#xff0c;采用插画、三维动画、微动效的创作方法&#xff0c;让用户感受到愉悦易用美观的使用体验。蓝蓝设计与知名企业合作项目有&…

5G基础知识

什么是 FDD 频分双工&#xff08;Frequency Division Duplexing&#xff09;&#xff0c;理解起来很简单&#xff0c;就是把上行和下行业务隔离在两个频段&#xff0c;互不干扰。 而 TDD 时分双工&#xff08;Time-Division Duplexing&#xff09;&#xff0c;是指上行下业务完…

使用 Elastic Observability 监控 dbt 管道

作者&#xff1a;来自 Elastic Almudena Sanz Oliv•Tamara Dancheva 了解如何使用 Elastic 设置 dbt 监控系统&#xff0c;该系统可主动发出数据处理成本峰值、每张表的行数异常以及数据质量测试失败的警报。 在 Elastic 可观察性组织内的数据分析团队中&#xff0c;我们使用 …

网站攻击,XSS攻击的类型

XSS&#xff08;跨站脚本&#xff09;攻击是一种网络安全攻击方式&#xff0c;攻击者通过在网站页面中注入恶意脚本&#xff0c;使脚本在其他用户的浏览器中执行&#xff0c;从而窃取用户信息、篡改页面内容或操控用户账户。这类攻击通常利用网站对输入数据的过滤不严格&#x…

数据库 示例解析

描述&#xff1a; 找出顾客订单中所花运费比他所下订单平均运费的两倍都还贵的订单号&#xff0c;列出cOrderNo。运费属性名为mShippingCost&#xff0c;顾客号属性为cCustomerID。 代码示例&#xff1a; SELECT o.cOrderNo FROM orders o WHERE o.mShippingCost > (SELE…