题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1183

题意:中文题啦~

思路:dp

用dp[i][j]表示从第一个字符开始,长度分别为i, j的两个字符串的编辑距离;

那么我们很容易能想到初始化为:dp[0][j]=j, dp[i][0]=i;

对于dp[i][j](其是a[0...i-1], b[0...j-1]的编辑距离),我们可以由三种情况得到:

1. 假设我们已经知道了 dp[i-1][j] 即 a[0...i-2], b[0...j-1]的编辑距离,那么我们只要往a[0...i-2]中再添加一个字符就能得到a[0...i-1], 所以dp[i][j]=dp[i-1][j]+1;

2. 假设我们已经知道了 dp[i][j-1] 即 a[0...i-1], b[0...j-2]的编辑距离,那么我们只要往b[0...j-2]中再添加一个字符就能得到b[0...j-1], 所以dp[i][j]=dp[i][j-1]+1;

3.1. 假设我们已经知道了 dp[i-1][j-1] 即 a[0...i-2], b[0...j-2]的编辑距离,如果a[i-1]=b[j-1], 那么dp[i][j]=dp[i-1][j-1], 如果a[i-1]!=b[j-1],那么我们需要改变a[i-1]

使其等于b[j-1],所以dp[i][j]=dp[i-1][j-1]+1;

所以我们得到状态转移方程式 :dp[i][j]=min(dp[i-1][j-1]+(a[i-1]==b[j-1]?0:1), min(dp[i-1][j]+1, dp[i][j-1]+1));

代码:

 #include <bits/stdc++.h>
#define MAXN 1010
using namespace std; int dp[MAXN][MAXN]; //dp[i][j]表示从第一个字符开始,长度分别为i, j的两个字符串的编辑距离
char a[MAXN], b[MAXN]; int main(void){
scanf("%s%s", a, b);
int lena=strlen(a), lenb=strlen(b);
for(int i=; i<=lena; i++){ //初始化
dp[i][]=i;
}
for(int i=; i<=lenb; i++){ //初始化
dp[][i]=i;
}
for(int i=; i<=lena; i++){
for(int j=; j<=lenb; j++){
dp[i][j]=min(dp[i-][j-]+(a[i-]==b[j-]?:), min(dp[i-][j]+, dp[i][j-]+));
}
}
printf("%d\n", dp[lena][lenb]);
return ;
}

51nod1183(Edit Distance)的更多相关文章

  1. [LeetCode] One Edit Distance 一个编辑距离

    Given two strings S and T, determine if they are both one edit distance apart. 这道题是之前那道Edit Distance ...

  2. [LeetCode] Edit Distance 编辑距离

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

  3. Edit Distance

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

  4. 编辑距离——Edit Distance

    编辑距离 在计算机科学中,编辑距离是一种量化两个字符串差异程度的方法,也就是计算从一个字符串转换成另外一个字符串所需要的最少操作步骤.不同的编辑距离中定义了不同操作的集合.比较常用的莱温斯坦距离(Le ...

  5. LintCode Edit Distance

    LintCode Edit Distance Given two words word1 and word2, find the minimum number of steps required to ...

  6. stanford NLP学习笔记3:最小编辑距离(Minimum Edit Distance)

    I. 最小编辑距离的定义 最小编辑距离旨在定义两个字符串之间的相似度(word similarity).定义相似度可以用于拼写纠错,计算生物学上的序列比对,机器翻译,信息提取,语音识别等. 编辑距离就 ...

  7. [UCSD白板题] Compute the Edit Distance Between Two Strings

    Problem Introduction The edit distinct between two strings is the minimum number of insertions, dele ...

  8. 动态规划 求解 Minimum Edit Distance

    http://blog.csdn.net/abcjennifer/article/details/7735272 自然语言处理(NLP)中,有一个基本问题就是求两个字符串的minimal Edit D ...

  9. One Edit Distance

    Given two strings S and T, determine if they are both one edit distance apart. 分析:https://segmentfau ...

随机推荐

  1. vue组件

    分享出来让思路更成熟. 首先组件是 Vue.js 最强大的功能之一. 可以减少很多的工作量,提高工作效率. 编写一个可复用性的组件,虽然官网上也有.... 编写可复用性的vue组件 具备一下的几个要求 ...

  2. Java开发环境搭建——Tomcat配置

    指定tomcat的JDK版本可能由于种种原因,系统的JAVA_HOME配置的JDK版本并不是当前需要的版本,而tomcat默认使用的是JAVA_HOME的JDK.可以通过修改tomcat/bin/ca ...

  3. AngularJS 细节

    AngularJS 表达式({{ expression }})类似于 AngularJS ng-bind 例子: <span>表达式</span> <div ng-app ...

  4. MVC Controller中View(model)如何在 View中的index页面获得?

    http://bbs.csdn.net/topics/390723984?page=1 在页面顶部定义@model List<UserModel>使用@foreach(var x in M ...

  5. Python 编码简单说

    先说说什么是编码. 编码(encoding)就是把一个字符映射到计算机底层使用的二进制码.编码方案(encoding scheme)规定了字符串是如何编码的. python编码,其实就是对python ...

  6. ThinkPHP框架下的表单验证

    之前的表单验证都是用js写的,这里也可以使用tp框架的验证.但是两者比较而言还是js验证比较好,因为tp框架验证会运行后台代码,这样运行速度和效率就会下降. 自动验证是ThinkPHP模型层提供的一种 ...

  7. MTK MT33xx型GPS的NMEA协议解析实例

    1)解析实现 gps_main.c #include <nmea/nmea.h> #include <string.h> #include <stdio.h> #i ...

  8. Oracle 中 decode 函数用法

    Oracle 中 decode 函数用法 含义解释:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下:IF 条件=值1 THEN RETURN(翻译 ...

  9. Nacl开发

    环境搭建:http://www.bojinxiaozhu.com/2014/0221/80.html http://blog.csdn.net/xoyojank/article/details/814 ...

  10. 如何删除已安装的Windows服务

    1) 开始-运行,输入regedit命令.  (Windows键+R,输入regdeit) 2) 回车后会弹出一个窗口:注册编辑器.找到 HKEY_LOCAL_MACHINE\SYSTEM\Curre ...