最小编辑代价

最小编辑代价问题:

对于两个字符串A和B,我们需要进行插入、删除和修改操作将A串变为B串,定义c0,c1,c2分别为三种操作的代价,请设计一个高效算法,求出将A串变为B串所需要的最少代价。

给定两个字符串AB,及它们的长度和三种操作代价,请返回将A串变为B串所需要的最小代价。保证两串长度均小于等于300,且三种代价值均小于等于100。

测试样例:
"abc",3,"adc",3,5,3,100
返回:8

问题分析:看到这道题,首先想到的是编辑距离问题,可以说是有异曲同工之处,但需要注意的是要将增删改的代价考虑进去。

注意:(1)增删的操作只能是在A串上操作,增加B[j]:h[i][j] = h[i][j-1]+c0;删除A[i]:h[i][j] = h[i-1][j]+c1;

(2)修改的操作要比较代价大小,因为删除一次再插入一次也可以看做是修改操作。

程序实现:

 1 class MinCost {
 2 public:
 3     int min2(int a,int b){
 4         return a<b?a:b;
 5     }
 6     int min3(int a,int b,int c){
 7         return min2(a,b)<c?min2(a,b):c;
 8     }
 9     int findMinCost(string A, int n, string B, int m, int c0, int c1, int c2) {
10         // write code here
11         int h[n+1][m+1];
12         h[0][0] = 0;
13         for(int i=1;i<=n;i++)
14             h[i][0] = i * c1;
15         for(int j=1;j<=m;j++)
16             h[0][j] = j * c0;
17         for(int i=1;i<=n;i++){
18             for(int j=1;j<=m;j++){
19                 if(A[i-1] == B[j-1])
20                     h[i][j] = h[i-1][j-1];
21                 else{
22                     int Delete_cost = h[i-1][j] + c1;//删除A[i]
23                     int Insert_cost = h[i][j-1] + c0;//插入B[j]
24                     int Modify_cost = h[i-1][j-1] + min2(c0+c1,c2);//修改A[i]为B[j]
25                     h[i][j] = min3(Delete_cost,Insert_cost,Modify_cost);
26                 }
27             }
28         }
29         return h[n][m];
30     }
31 };

转载请注明出处:

C++博客园:godfrey_88

http://www.cnblogs.com/gaobaoru-articles/

转载于:https://www.cnblogs.com/gaobaoru-articles/p/5452680.html

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

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

相关文章

Android中的数据库

2019独角兽企业重金招聘Python工程师标准>>> 1.1. 什么时候使用数据库 有大量相似结构的数据需要存储的时候就可以使用数据库。 1.2. SQLite的简介 SQLite是一款轻量级的数据库。它的设计目标是嵌入式的&#xff0c;而且目前已经在很多嵌入式产品中使用了它。Androi…

python计算绩效工资_python实现 --工资管理系统

原博文 2017-07-25 22:41 − # -*- coding: utf-8 -*- __author__ hjianli # import re import os info_message """Alex 100000 Rain 80000 Egon 50000 Yuan 30000 """ #序列字典 xulie_...01669 相关推荐 2019-09-28 21:13 − Python python…

为Windows Server 2012 R2指定授权服务器

为Windows Server 2012 R2指定授权服务器在Windows Server 2008 R2的终端服务中&#xff0c;可以手动指定授权服务器&#xff0c;而在Windows Server 2012 R2中&#xff0c;默认只能通过"远程桌面连接服务"管理器&#xff0c;指定授权服务器&#xff0c;而要使用远程…

spring5高级编程_Spring 5.X系列教程:满足你对Spring5的一切想象-持续更新

简介是什么让java世界变得更好&#xff0c;程序员变得更友爱&#xff0c;秃头率变得不是那么的高&#xff0c;让程序员不必再每天996&#xff0c;有时间找个女朋友&#xff1f;是Spring。是什么让企业级java应用变得简单易懂&#xff0c;降低了java程序员的进入门槛&#xff0c…

关于resolve非泛型方法不能与类型实参一起使用

今天mvc新建三层时&#xff0c;写到bll层中一直报下面的错误&#xff0c;检查了几遍赶脚并没有什么错。最后发现缺少一些引用。 如下面的图&#xff0c;少添加了下面的两个引用.Unity是微软模式与实践团队开发的一个轻量级、可扩展的依赖注入容器, Microsoft.Practices.Unity.C…

设计模式-Singleton

2019独角兽企业重金招聘Python工程师标准>>> Singleton算是知道的设计模式中最简单的最方便实现的了&#xff0c;模式实现了对于类提供唯一实例的方法&#xff0c;在很多系统中都会用到此模式。在实际项目中使用全局变量&#xff0c;或者静态函数等方式也可以达到这…

dump分析工具_Java应用CPU过高,如何排查?参考解决思路和常用工具总结

本文总结了一些常见的线上应急现象和对应排查步骤和工具。分享的主要目的是想让对线上问题接触少的同学有个预先认知&#xff0c;免得在遇到实际问题时手忙脚乱。毕竟作者自己也是从手忙脚乱时走过来的。只不过这里先提示一下。在线上应急过程中要记住&#xff0c;只有一个总体…

st官网下载stm32固件库方法

进入www.st.com官网------把网站改成中文&#xff08;就在右上方&#xff09;----点击产品-----选择右侧的微控制器选项------选择左侧的STM32 32位ARM CortexMCU-----选择左侧的STM32F1系列-----选择STM32103-----选择中间部分mcu对应型号&#xff08;我用的是STM32F103ZE)---…

mysql5.5提示Deprecated: mysql_query(): The mysql extension is deprecated

解决方法1&#xff1a;在php程序代码里面设置报警级别 <?php error_reporting E_ALL & ~E_DEPRECATED 方法2&#xff1a;禁止php报错 display_errors On 改为 display_errors Off 方法3&#xff1a;使用mysqli或者PDO 建议大家尽快取消mysql&#xff0c;全部都走…

JavaScript强化教程 —— Cocos2d-JS极速调试技巧

本文为 H5EDU 机构官方 HTML5培训 教程&#xff0c;主要介绍&#xff1a;JavaScript强化教程 —— Cocos2d-JS极速调试技巧 本文教大家一个调试Cocos2d-JS的小技巧&#xff0c;我都是这么用的&#xff0c;特意来告诉大家这个轻量快速的调试技巧。1.首先我们需要安装官方的cocos…

dos攻击命令_Kali Linux系列之拒绝服务攻击(DOS)实战(上)

(你的世界是个什么样的世界&#xff1f;你说&#xff0c;我们倾听!)-----------------小百科拒绝服务攻击即是攻击者想办法让目标机器停止提供服务&#xff0c;是黑客常用的攻击手段之一。其实对网络带宽进行的消耗性攻击只是拒绝服务攻击的一小部分&#xff0c;只要能够对目标…

stm32定时器配置

stm32通用定时器 STM32的定时器是个强大的模块&#xff0c;定时器使用的频率也是很高的&#xff0c;定时器可以做一些基本的定时&#xff0c;还可以做PWM输出或者输入捕获功能。 时钟源问题&#xff1a; 名为TIMx的有八个&#xff0c;其中TIM1和TIM8挂在APB2总线上&#xff0c;…

SQL 养成一个好习惯是一笔财富

来源&#xff1a;MR_ke 链接&#xff1a;http://www.cnblogs.com/MR_ke/archive/2011/05/29/2062085.html 我们做软件开发的&#xff0c;大部分人都离不开跟数据库打交道&#xff0c;特别是erp开发的&#xff0c;跟数据库打交道更是频繁&#xff0c;存储过程动不动就是上千行&a…

【JAVA】StringTokenizer 迭代方式对字符串进行分割

StringTokenizer是一个用来分隔String的应用类&#xff0c;相当于VB的split函数。1.构造函数public StringTokenizer(String str)public StringTokenizer(String str, String delim)public StringTokenizer(String str, String delim, boolean returnDelims)第一个参数就是要分…

python数组定义_python定义数组

广告关闭 腾讯云11.11云上盛惠 &#xff0c;精选热门产品助力上云&#xff0c;云服务器首年88元起&#xff0c;买的越多返的越多&#xff0c;最高返5000元&#xff01; 一、一维数组 1. 直接定义matrix2. 间接定义matrixprint(matrix)输出&#xff1a;3. 数组乘法matrix*5print…

Android-语言设置流程分析

Android手机语言切换行为&#xff0c;是通过设置-语言和输入法-语言来改变手机的语言&#xff0c;其实这个功能很少被用户使用。 以Android5.1工程源码为基础,从设置app入手来分析和学习语言切换的过程:一、语言设置界面&#xff1a;首先在设置app中找到语言设置这个Preference…

charles 安装 ssl_最全面的解决Charles手机抓包的证书问题(步骤非常详细)

源自公众号文章: 彻底解决Charles手机抓包的证书问题简介: Charles 抓包是日常开发当中经常会用到的技术, 在 Android 6 之前, 手机系统既信任系统内置的证书, 也信任用户自己安装的证书, 但是在 Android 7 之后, 却发生了变化, 手机系统只信任系统内置的根证书. 当然了, 这是为…

oracle报错:ORA-00054: 资源正忙,要求指定 NOWAIT

ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源&#xff1a; --首先得到被锁对象的session_idselect session_id from v$locked_object; --通过上面得到的session_id去取得v$session的sid和serial#&#xff0c;然后对该进程进行终止。--SELECT sid, serial#, username, o…

ARM中ROM,RAM,FLASH区别

RAM&#xff08;Random Access Memory&#xff09;的全名为随机存取记忆体&#xff0c;它相当于PC机上的移动存储&#xff0c;用来存储和保存数据的。它在任何时候都可以读写&#xff0c;RAM通常是作为操作系统或其他正在运行程序的临时存储介质&#xff08;可称作系统内存&…

excel 2007 vba与宏完全剖析_Excel宏VBA小技巧系列 | 分段加合

写在前面的话 知识产权算是一个盛产数据的行业。专利啊商标啊著作啊&#xff0c;都有著录项目。我们常说的专利分析、产业导航、企业导航、产业预警、竞争情报、技术综述、知识产权评议等等&#xff0c;常规操作之一就要先处理著录项目数据&#xff0c;然后再进行不同角度的分…