当前位置: 首页 > 编程日记 > 正文

Edit Distance

题意是求俩字符串的编辑距离,编辑定义有三种1、插入字符 2、删除字符 3、替换字符。

int minDistance(string word1, string word2) 
{
    if (word1.size() == 0) return (int)word2.size();
    if (word2.size() == 0) return (int)word1.size();
    
    int result = 0;
    int *dist = new int[(word1.size() + 1) * (word2.size() + 1)];
    
    for (size_t i = 0; i <= word1.size(); ++i)
    {
        dist[i] = (int)i;
    }
    
    for (size_t j = 0; j <= word2.size(); ++j)
    {
        dist[j * word1.size()] = (int)j;
    }
    
    for (size_t i = 1; i <= word1.size(); ++i)
    {
        for (size_t j = 1; j <= word2.size(); ++j)
        {
            if (word1[i - 1] == word2[j - 1])
            {
                // dist[i, j] = dist[i - 1, j - 1]
                dist[j * word1.size() + i] = 
                        dist[(j - 1) * word1.size() + i - 1];
            }
            else
            {
                // minDist = min(dist[i - 1, j], dist[i, j - 1])
                const int minDist = min(
                        dist[j * word1.size() + (i - 1)],
                        dist[(j - 1) * word1.size() + i]);
                
                // dist[i, j] = min(minDist, dist[i - 1, j - 1]) + 1
                dist[j * word1.size() + i] = min(minDist,
                        dist[(j - 1) * word1.size() + i - 1]) + 1;
            }
        }
    }
    
    result = dist[word2.size() * word1.size() + word1.size()];
    
    delete[] dist;
    
    return result;
}

转载于:https://www.cnblogs.com/codingmylife/archive/2012/09/09/2677301.html

相关文章:

【青少年编程】黄羽恒:翻译小工具 -- 利用百度翻译

「青少年编程竞赛交流群」已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 微信后台回复“资料下载”可获取以往学习的材料&#xff08;视频、代码、文档&…

UI设计师面试时如何介绍自己?

很多人在学会UI设计技术之后&#xff0c;那么接下来就是要进行面试找工作了&#xff0c;那么UI设计师面试时如何介绍自己?有哪些需要注意的呢?来看看下面的详细介绍。 UI设计培训分享&#xff1a;UI设计师面试时如何介绍自己? 一、投其所好 清楚自己的强项后&#xff0c;便可…

Silverlight:SSL教程

在Silverlight与WCF进行通信的过程中,数据安全就成为了一个非常关键的因素,如果不作任何限制,那么数据被抓包篡改等情况都是对系统的潜在威胁.本文主要介绍通过SSL配置WCF进行通信. 对于WCF的安全,主要分为传输/消息安全,在阅读本文时,你需要了解相关的知识,本文不做此部分介绍…

SANBoot安装系统

环境&#xff1a; 硬件&#xff1a;3台DELL R910无盘带2G SD卡 1台DELL MD3820F存储双控 2台光纤交换机 软件&#xff1a;windows server 2012 r2 with cu1 目标&#xff1a;R910服务器的系统从存储划分的lun中sanboot引导启动&#xff0c;并实现光纤双链路高可用&#xff0c;搭…

Datawhale组队学习周报(第012周)

本周&#xff08;05月03日~05月09日&#xff09;&#xff0c;第 24 期组队学习已经全部结营。另外&#xff0c;第 25 期组队学习也与大家见面了。我在这里要感谢所有的航路开辟者&#xff08;课程设计者&#xff09;&#xff0c;以及我们的航海士&#xff08;专业助教&#xff…

适合初学者的java书籍

学习java技术除了报Java培训班还有自学&#xff0c;书本知识一定不能忘了&#xff0c;书本知识带来的价值更直观&#xff0c;也方便记录&#xff0c;下面小编就为大家详细的介绍一下适合初学者的java书籍。 java培训分享适合初学者的java书籍&#xff1a; 1.Head First Java 首…

asp.net中web.config配置节点大全详解

web.config 文件查找规则&#xff1a; (1)如果在当前页面所在目录下存在web.config文件&#xff0c;查看是否存在所要查找的结点名称&#xff0c;如果存在返回结果并停止查找。 (2)如果当前页面所在目录下不存在web.config文件或者web.config文件中不存在该结点名&…

如何使用Python的进度条?

在使用Python处理比较耗时操作的时候&#xff0c;为了便于观察处理进度&#xff0c;就需要通过进度条将处理情况进行可视化展示&#xff0c;以便我们能够及时了解情况。这对于第三方库非常丰富的Python来说&#xff0c;并不是什么难事。 tqdm就能非常完美的支持和解决这个问题…

Python各种包下载地址

地址&#xff1a;https://www.lfd.uci.edu/~gohlke/pythonlibs/#lxml转载于:https://www.cnblogs.com/data-magnifier/p/7887072.html

Python中的标识符有哪些基础原则?

很多同学学习Python技术的过程中&#xff0c;会接触一些标识符的知识&#xff0c;这部分也是Python的基础知识&#xff0c;那么Python中的标识符有哪些基础原则?接下来我们一起来看看详细的内容介绍吧&#xff0c;希望对你们有Python培训所帮助&#xff0c;请看下文&#xff1…

[原]three.js 地形纹理混合

地形生成通常使用高度图&#xff0c; 而高度图的生成可以使用绘图工具&#xff0c;或者通过分形算法生成&#xff0c;例如square-diamond, fbm方法。这里采用简单求平均值随机波动的方法。对于一个2^n1 * 2^n1 的网格&#xff0c; 中心点的高度是四角点的平均值加随机偏移&a…

入职五年回顾(八) 2013年3月

今天是正月二十&#xff0c;香港高层们会过来派利是。人人能拿到的是一封二十元的利是&#xff0c;而高达三百元的利是则只有十二封&#xff0c;所以要抽奖。我们在新闻上看到腾讯逗利是的场景&#xff0c;但这也是发生在别人的公司。入职第一年逗利是&#xff0c;我脸皮不够厚…

UI设计的发展前景怎么样?

越来越多的人开始关注UI设计这个行业&#xff0c;有的人认为UI设计在业内发展很好&#xff0c;有的人却觉得工作比较难找&#xff0c;那么到底UI设计的发展前景怎么样呢?来看看下面的详细介绍就知道了。 UI设计的发展前景怎么样?可以从以下几个点出发&#xff1a; 一、偏运营…

[Struts2应用开发] JSON的应用

在日常的WEB应用开发过程中&#xff0c;前端常会涉及AJAX&#xff0c;而前台与后台的交互常用的数据格式就是JSON。 Struts2中使用JSON的方法方法如下&#xff1a; Action: 如果action中的某些属性不需要在json里面出现&#xff0c;可以通过annotation &#xff1a;JSON(serial…

2星|《快公司》2018年2-3期:商业人物访谈集

快公司2018年2期/2018年3期&#xff1a;乐观派领导力 本期杂志基本是一些商业人物的访谈集。大部分商业人物都是国内读者不熟悉的美国小公司的领导。 总体评价2星&#xff0c;参考价值不大。 以下是书中一些内容的摘抄&#xff0c;#号后面是kindle电子版中的页码&#xff1a; 1…

【青少年编程】【Scratch】06 侦测模块

06 侦测模块 侦测模块是用来检测场景中某一参数的变化&#xff0c;通过参数变化来为下一步操作提供运行依据。通常与控制模块中的条件语句和循环语句一起使用。 具体分为&#xff1a; 与运动相关的侦测&#xff1b;与按键相关的侦测&#xff1b;侦测舞台、角色等的基本参数&…

Java培训教程:”==“和 equals 方法究竟有什么区别?

在学习java技术过程中&#xff0c;我们会接触到一些变量值的相关知识&#xff0c;本期小编为大家介绍的教程就是关于”“和 equals 方法究竟有什么区别?来看看下面的详细介绍。 Java培训教程&#xff1a;”“和 equals 方法究竟有什么区别? 操作符专门用来比较两个变量的值是…

转载-SQL Server各种导入导出数据方式的比较

注&#xff1a;本文转载自 http://blog.csdn.net/nokiaguy/article/details/4684822 当我们建立一个数据库时&#xff0c;并且想将分散在各处的不同类型的数据库分类汇总在这个新建的数据库中时&#xff0c;尤其是在进行数据检验、净化和转换时&#xff0c;将会面临很大的挑战。…

【直播】李祖贤:集成学习答疑直播之八-- 集成知识点回顾与补充

集成学习答疑直播之八-- 集成知识点回顾与补充 集成学习是首个横跨3个周期的长期组队学习&#xff0c;在第25期组队学习中进行到“第三期-模型融合与数据实战”阶段。组队学习期间&#xff0c;课程设计者每周针对学习任务的重难点和学员的学习情况进行集中直播答疑&#xff0c;…

Python培训完可以找什么工作

近几年学习Python技术的人越来越多&#xff0c;对于Python这个行业很多人都是比较看好的&#xff0c;事实也确实如此&#xff0c;那么具体Python培训完可以找什么工作呢?现在学习Python好就业吗?来看看下面的详细介绍吧。 Python培训完可以找什么工作?Python是一种面向对象的…

上传图片时出现Request 对象 错误 'ASP 0104 80004005'

原因.IIs默认的上传大小为200K,当上传的文件超过此大小.则会出现此错误 解决办法: 1.关闭IIS Admin Service服务 2.更改C:\WINDOWS\system32\inetsrv目录下的MetaBase.xml 文件,将第601行的AspMaxRequestEntityAllowed204800.更改为AspMaxRequestEntityAllowed5120000(5120000是…

Datawhale组队学习周报(第013周)

本周&#xff08;05月10日~05月16日&#xff09;&#xff0c;第 25 期组队学习正在如火如荼的进行中。本期组队学习&#xff0c;一共有 3 门开源课程&#xff0c;共组建了 3 个学习群&#xff0c;参与的学习者有 292 人。另外&#xff0c;第 26 期组队学习也蓄势待发准备与大家…

subst将文件夹目录虚拟成虚拟磁盘

SUBST [drive1: [drive2:]path]SUBST drive1: /Ddrive1: 指定要指派路径的虚拟驱动器。[drive2:]path 指定物理驱动器和要指派给虚拟驱动器的路径。/D 删除被替换的 (虚拟) 驱动器。不加任何参数键入 SUBST&#xff0c;可以显示当前虚拟驱动器的清单。本文…

UI设计学习的对比原则怎么运用?

本期小编为大家介绍的UI设计培训教程就是关于UI设计学习的对比原则怎么运用?因为在UI设计中分组原则这一项在文字排版中运用的几率是比较频繁的&#xff0c;并且分组对于层次感和整合信息都有一定的帮助&#xff0c;但是光有分组还远远不够&#xff0c;尤其是零基础学ui我们还…

silverlight数据库应用程序开发

该解决方案使用的是"silverlight导航应用程序Oracle数据库WebService服务” 新建silverlight项目GH&#xff0c;同时会自动添加一个GH.Web,在GH.Web中添加"web 服务"&#xff0c;同时需要添加两个XML文件用于解决跨域问题&#xff1a; 第一个XML文件&#xff1a…

如何设置matplotlib中x,y坐标轴的位置?

在机器学习中经常会使用Sigmoid函数&#xff0c;如果直接使用matplotlib绘图&#xff0c;那么就会像下图这样&#xff0c;原点并没有在(0,0)。 import matplotlib.pyplot as plt import numpyx numpy.linspace(start-10, stop10) y 1 / (1 numpy.e ** (-1 * x))plt.plot(x,…

Python中的类、模块和包究竟是什么?

Python培训教程&#xff1a;Python中的类、模块和包究竟是什么?在Python和其他编程语言中&#xff0c;都有类似或相同的概念&#xff0c;如对象、类、模块、包&#xff0c;名称都是一样的&#xff0c;只不过会有细微的一些区别&#xff0c;正是因为有这些存在&#xff0c;才使…

Test class should have exactly one public constructor解决办法

测试类用的junit&#xff0c;在eclipse中执行ok&#xff0c;在maven编译就挂 Error MessageTest class should have exactly one public constructor Stacktracejava.lang.Exception: Test class should have exactly one public constructorat org.junit.runners.BlockJUnit4C…

中矿大新生赛 A 求解位数和【字符串】

时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K64bit IO Format: %lld题目描述 给出一个数x&#xff0c;求x的所有位数的和。输入描述: 第1行输入组数T&#xff0c;代表有T组数据。第2-T1行&#xff0c;每行输入…