题目:

给定两个字符串str1和str2,在给定三个整数ic,dc和rc,分别代表插入、删除和替换一个 字符,返回将str1编辑成str2的最小代价。

解题方法:

动态规划。首先生成大小为(M+1)X(N+1)的矩阵dp。

假设str1="av=b12cd3", str2="abcdf"。dp[i][j]表示str1[0:i]编辑成str2[0:j]的最小代价。计算结果如下:

计算步骤:

1、dp[0][0]表示str1空的子串编辑成str2空的子串的代价为0

2、矩阵dp第一列即dp[0:M-1][0], dp[i][0] 表示str1[0:i-1]编辑成空串的最小代价,即把str1[0:i-1]中所有字符删掉的代价,所以dp[i][0] = dc * i

3、矩阵第一行即dp[0][0:N-1], dp[0][j]表示空串编辑成str2[0:j-1]的最小代价,即向空串中添加字符的代价,所以dp[0][j] = ic * j

4、其他位置,从左到右,从上到下计算,dp[i][j]的值可能来自于一下四种情况:

(1)str1[0:i-1]先编辑成str1[0:i-2],即先删除字符str1[i],然后由str1[0:i-2]编辑成str2[0:j-1],dp[i-1][j] 表示str1[0:i-2]编辑成石头人[0:j-1]的最小代价,那么dp[i][j]可能等于dc + dp[i-1][j]

(2)str1[0:i-1]可以先编辑成str2[0:j-2],然后向str2[0:j-2]插入字符str2[j-1],编辑成str2[0:j-1],dp[i][j-1]表示str1[0:i-1]编辑成str2[0:j-2]的最小代价,那么dp[i][[j]可能等于dp[i][j-1] + ic;

(3) 如果str1[i-1] != str2[j-1], 可以先将str1[0:i-2]编辑成str2[0:j-2],然后将str1[i-1]替换成str2[j-1],dp[i-1][j-1]表示将str1[0:i-2]编辑成str2[0:j-2]的最小代价,那么dp[i][j]可能等于dp[i-1][j-1]+rc

(4)如果str1[i-1] == str2[j-1], 则此时dp[i][j] = dp[i-1][j-1]

具体代码如下:

func GetDp(str1, str2 []rune, ic, dc, rc int)int{rows := len(str1) + 1cols := len(str2) + 1dp := make([][]int, rows)for i, _ := range dp {dp[i] = make([]int, cols)}for i:=0;i < cols;i++{dp[0][i] = ic * i}for i:=0;i < rows;i++{dp[i][0] = dc * i}for i:=1;i<rows;i++{for j:=1;j<cols;j++{if str1[i-1] == str2[j-1]{dp[i][j] = dp[i-1][j-1]}else{dp[i][j] = dp[i-1][j-1] + rc}dp[i][j] = getMin(dp[i][j], dp[i][j-1]+ic)dp[i][j] = getMin(dp[i][j], dp[i-1][j] + dc)}}return dp[rows-1][cols-1]
}

  

转载于:https://www.cnblogs.com/youhongpp/p/8973668.html

最小编辑代价-golang相关推荐

  1. 动态规划示例汇总-Java版(组合硬币、跳台阶、最小路径和、最长递增子序列、最长公共子序列、01背包问题、最小编辑代价)

    动态规划算法示例汇总-Java版 组合硬币 Java解题-暴力搜索 Java解题-记忆搜索 Java解题-动态规划(两种写法) 跳台阶 Java解题-暴力递归 Java解题-动态规划 矩阵最小路径和 ...

  2. 动态规划 最小编辑代价

    题目描述: 给定两个字符串str1和str2,再给定三个整数ic,dc,rc,分别代表插入.删除.替换一个字符的代价,返回将str1编辑成str2的最小代价. 举例: str1="abc&q ...

  3. 最小总代价(洛谷-U17433)

    题目描述 n个人在做传递物品的游戏,编号为1-n. 游戏规则是这样的:开始时物品可以在任意一人手上,他可把物品传递给其他人中的任意一位:下一个人可以传递给未接过物品的任意一人. 即物品只能经过同一个人 ...

  4. Java动态规划---矩阵链相乘的最小计算代价

    参考书籍:算法导论第三版. 采用自底向上的递归模式来求解. * 动态规划在矩阵链相乘的应用,目的求出最小的计算代价,即矩阵的计算顺序,用加小括号表示. * 主要的计算思想是递归,而且是带备忘录的递归, ...

  5. Lintcode 背包专题:最小调整代价,杆子分割,换硬币

    一.最小调整代价 给一个整数数组,调整每个数的大小,使得相邻的两个数的差不大于一个给定的整数target,调整每个数的代价为调整前后的差的绝对值,求调整代价之和最小是多少. 样例 对于数组[1, 4, ...

  6. 【白板推导系列笔记】降维-PCA-最大投影方差最小重构代价

    作者:shuhuai008 链接:[机器学习][白板推导系列][合集 1-33]_哔哩哔哩_bilibili PCA的核心就是对原始特征空间的重构(将一组可能线性相关的变量,通过正交变换变换成一组线性 ...

  7. 霍夫曼树之切割木板最小总代价问题

    对于本题的切割方案,在给出了最终的切割结果后,我们其实可以使用倒推的方法,将最终的小木板不断合成大木板,大木板的长度就是本次合并的开销,和相同条件下的切割的开销是一样的. 这样想的话,想要总开销小的话 ...

  8. 12-降维-PCA-最大投影方差/最小重构代价

    文章目录 1.PCA(principal component analysis)主成分分析定义 2.PCA中心思想:一个中心,两个基本点 3.PCA数学建模-最大投影方差 3.1数据中心化处理-最大投 ...

  9. 《程序员代码面试指南第二版》Python实现(个人读书笔记)

    说明 最近在读左神的书---<程序员代码面试指南-IT名企算法与数据结构题目最优解(第二版)>以及看了一些左神的基础.进阶.高频等视频课程,为了记录自己的学习成果,并且方便以后查看,将自己 ...

最新文章

  1. Elasticsearch Top 51 重中之重面试题及答案
  2. 高效编程之互斥锁和自旋锁
  3. 【机器学习】坐标下降法(Coordinate descent)
  4. 使用Lightbox制作照片条
  5. 矩阵问题入门(矩阵乘法and矩阵快速幂)acm寒假集训日记22/1/15
  6. MyBatis第3天
  7. linux下NIS搭建(六)
  8. NAT with same subnetwork
  9. 信息系统开发与利用 领域分析部分@wangshushu
  10. 最全汇总GAN网络及其各种变体(附论文及代码实现)
  11. 【超图+CESIUM】【基础API使用示例】18、超图|CESIUM - 标绘点位:Cesium.DrawHandler绘制点位Cesium.DrawMode.Point
  12. 报刊资料整理:云安全(cloud security)
  13. 期货反向对冲核心思维跟单策略
  14. html和js制作个人所得税表格,用JS编写个人所得税计算器
  15. 【论文阅读】A Survey of Incentive Mechanism Design for Federated Learning 联邦学习激励机制设计综述
  16. vite打包工具的介绍
  17. 向左转移测试需要整个团队的努力
  18. 关于服务端的FIN_WAIT2
  19. java ldj_面试小记--python相关常识
  20. python截取字符串后三位_python如何截取字符串后几位

热门文章

  1. php引用对象方法吗,在PHP中引用容器对象的方法?
  2. 在下列计算机应用项目中,属于过程控制应用领域的是,计算机基础试题.ppt
  3. linux系统基础与应用,Linux操作系统:基础、原理与应用
  4. 设置角标_iPhone桌面角标颜色
  5. MySQL 锁的相关知识 | lock与latch、锁的类型、简谈MVCC、锁算法、死锁、锁升级
  6. Python(28)-异常
  7. 哈希表和有序表的简单介绍
  8. 中科大 计算机网络15 DNS域名解析系统
  9. 中科大 计算机网络12 Web和HTTP
  10. 解决 idea 中 jsp 修改后页面不生效