一、实践题目

设A和B是2个字符串。要用最少的字符操作将字符串A转换为字符串B。这里所说的字符操作包括:
()删除一个字符;
()插入一个字符;
()将一个字符改为另一个字符。
将字符串A变换为字符串B所用的最少字符操作数称为字符串A到 B的编辑距离,记为d(A,B)。
对于给定的字符串A和字符串B,计算其编辑距离 d(A,B)。 输入格式:
第一行是字符串A,文件的第二行是字符串B。 提示:字符串长度不超过2000个字符。 输出格式:
输出编辑距离d(A,B) 输入样例:
在这里给出一组输入。例如: fxpimu
xwrs
输出样例:
在这里给出相应的输出。例如:

二、问题描述

题目大意是:给出两个字符串 a、b,可以通过增删改三个操作将a变成b,需要进行几次操作。

三、算法描述

这道题类似于求最长公共子序列,但是还是更高级一点的。我用了res [2002][2002]来存储结果,res[i][j]表示a的子串(下标从0到i)转化为b的子串(下标从0到j)需要的操作次数,因此本题结果是res[strlen(a)][strlen(b)]。

那么问题就转化为求出res数组。

本题的res数组:

a \ b x w r s
f 2 3 4
x 1 2 3 4
p 2 2 3 4
i 3 3 3 4
m 4 4 4 4
u 5 5 5 5

1、初始化:当strlen(a)=0,res[0][j]=j;同理可得res[i][0]=i;

2、当a[i-1]=b[j-1],则res[i][j]=res[i-1][j-1],即等于左上角的元素;

3、当a[i-1]!=b[j-1],有以下三种情况:

(1)若进行删除操作:操作数加1,res[i][j]=res[i-1][j]+1;

(2)若进行增加操作:操作数加1,res[i][j]=res[i][j-1]+1;

(3)若进行替换操作:操作数加1,res[i][j]=res[i-1][j-1]+1;

  res[i][j]等于上面三种情况res[i][j]里的最小值

通过以上分析,我们可以发现填表规则是从上到下从左往右填一个大小为strlen(a)*strlen(b)的表格,两层for循环对res数组操作:匹配时取左上的值;

失配时取 左上+1,左边+1,右边+1 三个数中的最小值,更新res[i]][j];

最后递推到右下角dp[la][lb]为所求答案

代码如下:

 #include<iostream>
#include<string.h>
using namespace std;
char a[], b[];
int res [][];
int temp = ;
int main (){
cin >> a;
cin >> b;
int la = strlen (a);
int lb = strlen (b);
for(int i = ; i <= la; i++) res[i][] = i;
for(int i = ; i <= lb; i++) res[][i] = i; for(int i = ; i <= la; i++){
for(int j = ; j <= lb; j++){
if(a[i-] == b[j-]) temp = ; else temp = ;
int t = min(res[i-][j] + ,res[i][j-] + );
res[i][j] = min(t,res[i-][j-] + temp);
}
} cout << res[la][lb];
return ;
}

四、算法时间及空间复杂度分析

采用dp思想,两层for循环处理res数组,故时间复杂度为O(n^2)

五、心得体会

dp问题最重要的还是要找到问题的最优解子结构,然后建立递推关系,确定好填表的顺序。

多打题,才能提高、加深对算法的理解。

PTA 7-3 编辑距离问题 (30 分)的更多相关文章

  1. PTA 7-1 公路村村通 (30分)

    PTA 7-1 公路村村通 (30分) 现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本. 输入格式: 输入数据包括城镇数目正整数N ...

  2. PTA 练习 7-24 喊山 (30 分)

    7-24 喊山 (30 分) 喊山,是人双手围在嘴边成喇叭状,对着远方高山发出"喂-喂喂-喂喂喂--"的呼唤.呼唤声通过空气的传递,回荡于深谷之间,传送到人们耳中,发出约定俗成的& ...

  3. PTA 08-图7 公路村村通 (30分)

    现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本. 输入格式: 输入数据包括城镇数目正整数NN(\le 1000≤1000)和候选道 ...

  4. PTA 1014 Waiting in Line (30分) 解题思路及满分代码

    题目 Suppose a bank has N windows open for service. There is a yellow line in front of the windows whi ...

  5. PTA 社交网络图中结点的“重要性”计算(30 分)

    7-12 社交网络图中结点的“重要性”计算(30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓延的一种相互 ...

  6. 二叉搜索树的结构(30 分) PTA 模拟+字符串处理 二叉搜索树的节点插入和非递归遍历

    二叉搜索树的结构(30 分) PTA 模拟+字符串处理 二叉搜索树的节点插入和非递归遍历   二叉搜索树的结构(30 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则 ...

  7. PTA 11-散列4 Hard Version (30分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/680 5-18 Hashing - Hard Version   (30分) Given ...

  8. PTA 05-树9 Huffman Codes (30分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/671 5-9 Huffman Codes   (30分) In 1953, David ...

  9. PTA 04-树6 Complete Binary Search Tree (30分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/669 5-7 Complete Binary Search Tree   (30分) A ...

随机推荐

  1. DevOps平台

    DevOps定义(来自维基百科): DevOps(Development和Operations的组合词)是一种重视"软件开发人员(Dev)"和"IT运维技术人员(Ops) ...

  2. 简单说一下你对http和https的理解

    http是一种超文本传输协议,传输的数据都是未加密的,也就是显示在明面上的,是现在互联网上应用最为广泛的一种网络协议,相对来说不太安全,但是所需成本很小.http一般的端口号为80. https则是具 ...

  3. Java单元测试之JUnit 5快速上手

    前言 单元测试是软件开发中必不可少的一环,但是在平常开发中往往因为项目周期紧,工作量大而被选择忽略,这样往往导致软件问题层出不穷.线上出现的不少问题其实在有单元测试的情况下就可以及时发现和处理,因此培 ...

  4. Java线程的几种状态(基于Oracle jdk 1.8)

    Java中线程的状态定义在java.lang.Thread类中的一个枚举中. public enum State { /** * Thread state for a thread which has ...

  5. Winform中通过代码设置DevExpress的TextEdit的类型为Numbernic

    场景 使用DevExpress的EditText控件时,需要限制其输入类型为数字. 正常来说是窗体上拖拽一个TextEdit,然后在设计窗口点击小三角,选择Change Mask 但是如果说TextE ...

  6. 加入百度地图遇到 framework not found BaiduMapAPI***

    新建一个文件夹,把需要的静态库和.h文件放到文件夹里面.就解决啦.虽然不知道为什么这样可以,但是可以使用啦~~~

  7. 解决mysql不能在查询A表的同时,更新A表的问题

    方法: 运用中间表 UPDATE 表名 SET 字段名 = '' WHERE id in (SELECT a.id FROM (SELECT id FROM 表名 WHERE ISNULL(字段名)) ...

  8. (5)Makefile详解

         Makefile是一个自动化的编译工具,关系到整个工程的编译规则,极大的提高了软件开发的效率.     (1)Makefile的编译规则 //Makefile 也可以写作 makefile1 ...

  9. LoadRunner11.安装破解

    Loadrunner安装及破解   一. 安装 1. 将ISO文件导入,打开光驱,运行“setup.exe” 2. 点击安装,部分机器会提示缺少“Microsoft Visual C++ 2005 S ...

  10. jenkins自动化部署项目8 -- 新建job(服务代码部署在linux上)

    jenkins(windows) ----> 应用服务器(linux): 1.后台java服务: 与部署在windows上不同的是,这里我选择了在[构建后操作]中使用ssh向远程linux服务器 ...