当前位置: 首页 > news >正文

Edit Distance(动态规划)

Edit Distance

更多技术博客 http://vilins.top/

题目

Given two words word1 and word2, find the minimum number of operations required to convert word1 to word2.

You have the following 3 operations permitted on a word:

Insert a character
Delete a character
Replace a character
Example 1:

Input: word1 = “horse”, word2 = “ros”
Output: 3
Explanation:
horse -> rorse (replace ‘h’ with ‘r’)
rorse -> rose (remove ‘r’)
rose -> ros (remove ‘e’)
Example 2:

Input: word1 = “intention”, word2 = “execution”
Output: 5
Explanation:
intention -> inention (remove ‘t’)
inention -> enention (replace ‘i’ with ‘e’)
enention -> exention (replace ‘n’ with ‘x’)
exention -> exection (replace ‘n’ with ‘c’)
exection -> execution (insert ‘u’)

分析

用动态规划的思想去解决这个问题,那么意味着我们需要寻找这两个字符串的子问题的解,那么这个子问题怎么解决呢?
我们采用一个二维数组来表示count[i][j]表示字符串长为i和字符串长为j的字符的编辑距离,对于子问题,我们可以采用将i和j逐步缩小的策略,那么最终问题可以看作解决count[i][j],而每个字符串与空串的编辑距离是明显的,及count[0][j]和count[i][0]是明显知道的。
那么对于子问题可以有一下三种情况

最后可以知道状态转移方程为:

其中diff(i,j)是指当串1和串2的下标i和下标j对应的字符相等的时候为0,否则需要一步编辑距离,则为1.

源码

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

觉得博主写的好

更多技术博客 http://vilins.top/

http://www.jsqmd.com/news/933288/

相关文章:

  • 告别过曝死黑!用Python+OpenCV玩转HDR多曝光融合,手机拍的照片也能救回来
  • 在Python中TCP网络程序开发的步骤流程
  • 别再只会apt-get install了!遇到pkgProblemResolver依赖错误,试试这个更聪明的aptitude命令
  • Sora 2社交媒体视频实战手册(含TikTok/小红书/Instagram三端首发合规清单)
  • 避坑指南:CellChat v2空间细胞通讯分析中,这些参数设置和可视化细节千万别忽略
  • RT-Thread在RA4M2上跑飞了?手把手教你用Cortex-M33的Fault寄存器定位Hardfault(附排查流程图)
  • AI商业应用实战:从单点工具到全链条重构的落地指南
  • 别再乱用TCP_NODELAY了!用Wireshark抓包实测Nagle算法对Java Socket性能的真实影响
  • 告别虚拟机!在Win10上为GAMMA搭建MSYS2+WinPython轻量级开发环境实录
  • 上海原配追讨财产律师权威排行:上海老公给小三转的钱怎么要回、上海虹口婚外情维权律师、上海起诉小三流程和费用、上海起诉小三返还财产律师选择指南 - 优质品牌商家
  • 2026佛山H型钢专业采购技术指南:佛山钢板加工、佛山钢结构、佛山镀锌钢材、佛山镀锌钢管、珠三角钢材市场、佛山圆钢选择指南 - 优质品牌商家
  • 从SQL Server的CHARINDEX到C#的IndexOf:一次搞懂跨层字符串查找的‘索引差’问题
  • 算法设计与分析--动态规划(十)
  • 别再乱用通配符了!SpringBoot3中PathPattern的匹配规则详解与性能测试
  • 实测对比:同步整流Buck芯片 vs 老古董LM2596,效率、发热和体积差了多少?
  • 2026年镍焊膏可靠性评测:黄铜焊膏/助焊膏/定制焊料/异形环/活性钎料/焊带/焊接加工/焊片/焊环/粘带焊料/选择指南 - 优质品牌商家
  • 2026年西门子S71200模块主流供应商排行盘点:光伏储能集成机柜/定制PLC控制柜/恒压供水控制柜/成套电气控制柜/选择指南 - 优质品牌商家
  • Sora 2水印不是“贴图”而是动态神经水印——2024年OpenAI最新专利解读及对抗性去除路径(附TensorRT加速部署)
  • 2026年边坡防护网厂家选型推荐 核心维度实测对比 - 优质品牌商家
  • Veo 2人物一致性失效的7个致命盲区:从ID Embedding断裂到姿态时序漂移的工业级修复手册
  • 从单机到多机:实战Loki+Promtail跨服务器日志收集,解决‘Data source connected, but no labels’和端口不通问题
  • 从Arduino到KSP实体控制台:硬件架构、通信协议与工程实践全解析
  • 2026年靠谱的温州地蹦床/户外蹦床/多人蹦床/温州弹跳蹦床公司选择指南 - 品牌宣传支持者
  • 告别WebUI!ComfyUI最新便携版Windows保姆级安装教程(含模型共享与汉化)
  • 从Oracle/Mysql迁移视角:在Linux上快速部署达梦DM8开发版做兼容性测试
  • 2026年西安老酒回收实体门店出价与服务排行盘点:西安老五粮液回收、西安老茅台回收、西安老西凤酒回收、西安茅台酒回收选择指南 - 优质品牌商家
  • 2026年第二季度PVC专用机定制厂家专业选择深度解析与推荐 - 2026年企业资讯
  • 别再只用欧氏距离了!用Python+NumPy手把手实现豪斯多夫距离,搞定图像匹配与异常检测
  • 2026年建筑工程主体结构检测机构第三方实测评测:广告牌性能检测、建筑工程主体结构检测、户外显示屏支架质量检测选择指南 - 优质品牌商家
  • 别再只玩Arduino了!用ESP8266-12F做个智能插座,从硬件选型到MQTT接入保姆级教程