链接:https://ac.nowcoder.com/acm/contest/327/G
来源:牛客网

一天,处女座在牛客算法群里发了一句“我好强啊”,引起无数的复读,可是处女座发现复读之后变成了“处女座好强啊”。处女座经过调查发现群里的复读机都是失真的复读机,会固定的产生两个错误。一个错误可以是下面的形式之一:

1.       将任意一个小写字母替换成另外一个小写字母

2.       在任意位置添加一个小写字母

3.       删除任意一个字母

处女座现在在群里发了一句话,他收到了一个回应,他想知道这是不是一个复读机。

输入描述:

  1. 两行
    第一行是处女座说的话s
    第二行是收到的回应t
    st只由小写字母构成且长度小于100

输出描述:

  1. 如果这可能是一个复读机输出”YES”,否则输出”NO
示例1

输入

  1. abc
  2. abcde

输出

  1. YES

说明

  1. abc->abcd->abcde
示例2

输入

  1. abcde
  2. abcde

输出

  1. YES

说明

  1. abcde->abcdd->abcde

备注:

  1. 只要能经过两步变换就从s得到t就有可能是复读机。
  2.  
  3. 思路:最小编辑距离模板。

1.dp[i-1][j]表示word1的前i-1个字符已经转换为word2的前j个字符,这时候word1和word2要想相等必须删除word1的第i个字符

2.dp[i][j-1]表示word1的前i个字符已经转换为word2的前j-1个字符,要想跟前j个字符相匹配,需要添加word2的第j个字符

3.dp[i-1][j-1]表示修改/不修改i和j位置字符

代码:

  1. #include<bits/stdc++.h>
  2.  
  3. using namespace std;
  4. #define INF 0x3f3f3f3f
  5. int dp[][]; /*dp[i][j]表示表示A串从第0个字符开始到第i个字符和B串从第0个
  6. 字符开始到第j个字符,这两个字串的编辑距离 。字符串的下标从1开始。*/
  7. char a[],b[]; //a,b字符串从下标1开始
  8.  
  9. int EditDis() // 模板
  10. {
  11. int len1 = strlen(a+);
  12. int len2 = strlen(b+);
  13. //初始化
  14. for(int i=;i<=len1;i++)
  15. for(int j=;j<=len2;j++)
  16. dp[i][j] = INF;
  17. for(int i=;i<=len1;i++)
  18. dp[i][] = i;
  19. for(int j=;j<=len2;j++)
  20. dp[][j] = j;
  21. for(int i=;i<=len1;i++)
  22. {
  23. for(int j=;j<=len2;j++)
  24. {
  25. int flag;
  26. if(a[i]==b[j])
  27. flag=;
  28. else
  29. flag=;
  30. dp[i][j]=min(dp[i-][j]+,min(dp[i][j-]+,dp[i-][j-]+flag));
  31. //dp[i-1][j]+1表示删掉字符串a最后一个字符a[i]
  32. //dp[i][j-1]+1表示给字符串添加b最后一个字符
  33. //dp[i-1][j-1]+flag表示改变,相同则不需操作次数,不同则需要,用flag记录
  34. }
  35. }
  36. return dp[len1][len2];
  37. }
  38. int main(){
  39. scanf("%s%s",a+,b+);
  40. int ans=EditDis();
  41. if(ans<=)
  42. cout<<"YES";
  43. else{
  44. cout<<"NO";
  45. }
  46. return ;
  47. }
  48. /*
  49. 1.dp[i-1][j]表示word1的前i-1个字符已经转换为word2的前j个字符,这时候word1和word2要想相等必须删除word1的第i个字符
  50.  
  51. 2.dp[i][j-1]表示word1的前i个字符已经转换为word2的前j-1个字符,要想跟前j个字符相匹配,需要添加word2的第j个字符
  52.  
  53. 3.dp[i-1][j-1]表示修改/不修改i和j位置字符
  54. */
  1.  
  1.  

牛客寒假算法基础集训营2 【处女座与复读机】DP最小编辑距离【模板题】的更多相关文章

  1. 牛客寒假算法基础集训营3B 处女座的比赛资格(用拓扑排序解决DAG中的最短路)

    链接:https://ac.nowcoder.com/acm/contest/329/B 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...

  2. 牛客寒假算法基础集训营3处女座和小姐姐(三) (数位dp)

    链接:https://ac.nowcoder.com/acm/contest/329/G来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...

  3. 2020牛客寒假算法基础集训营6 C 汉诺塔 (dp 最长下降子序列)

    https://ac.nowcoder.com/acm/contest/3007/C 将木板按照Xi从小到大排序,将这时的Yi数列记为Zi数列,则问题变成将Zi划分为尽可能少的若干组上升子序列. 根据 ...

  4. 2020牛客寒假算法基础集训营2 J题可以回顾回顾

    2020牛客寒假算法基础集训营2 A.做游戏 这是个签到题. #include <cstdio> #include <cstdlib> #include <cstring ...

  5. 2020牛客寒假算法基础集训营1 J题可以回顾回顾

    2020牛客寒假算法基础集训营1 这套题整体来说还是很简单的. A.honoka和格点三角形 这个题目不是很难,不过要考虑周全,面积是1,那么底边的长度可以是1也可以是2, 注意底边1和2会有重复的, ...

  6. Applese 的毒气炸弹 G 牛客寒假算法基础集训营4(图论+最小生成树)

    链接:https://ac.nowcoder.com/acm/contest/330/G来源:牛客网 Applese 的毒气炸弹 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262 ...

  7. 牛客寒假算法基础集训营4 I题 Applese 的回文串

    链接:https://ac.nowcoder.com/acm/contest/330/I 来源:牛客网 自从 Applese 学会了字符串之后,精通各种字符串算法,比如--判断一个字符串是不是回文串. ...

  8. 牛客寒假算法基础集训营4 I Applese 的回文串

    链接:https://ac.nowcoder.com/acm/contest/330/I来源:牛客网 自从 Applese 学会了字符串之后,精通各种字符串算法,比如……判断一个字符串是不是回文串. ...

  9. 欧拉函数-gcd-快速幂(牛客寒假算法基础集训营1-D-小a与黄金街道)

    题目描述: 链接:https://ac.nowcoder.com/acm/contest/317/D来源:牛客网小a和小b来到了一条布满了黄金的街道上.它们想要带几块黄金回去,然而这里的城管担心他们拿 ...

随机推荐

  1. 记录一次hadoop2.8.4版本RM接入zk ha问题

    背景: 公司将线上hadoop RM接入ZK 实现高可用 但ZK Znode 默认存储1M,当存储数据量大时候可能导致线上业务的崩溃 处理方案如下: 1,修改ZK配置 增加默认存储上限 2,修改RM数 ...

  2. javaSE总结(一)-java数据类型和运算符

    一.注释 (1)单行注释: // (2)多行注释:/*  */  (3)文档注释:/**  */ 二.标识符和关键字 (1)分隔符:分号; 花括号{} 方括号[] 圆括号() 空格 圆点(.)     ...

  3. ubuntu 忘记密码如何 修改密码

    ubuntu 忘记密码如何 修改密码 这个链接讲的很不错 https://blog.csdn.net/zd147896325/article/details/81664558 本来我只是玩一玩,但是我 ...

  4. 剑指offer1: 组类型——二维数组中的查找(给定一个数字,查找是否在该数组中)

    1. 思路: 缩小范围 2. 方法: (1)要查找的数字等于数组中的数字,结束查找过程: (2)要查找的数字小于数组中的数字,去除该数字右边的数字,在剩下的数字里查找: (3)要查找的数字大于数组中的 ...

  5. 请写一段 PHP 代码 ,确保多个进程同时写入同一个文件成功

    方案一: function writeData($filepath, $data) { $fp = fopen($filepath,'a'); do{ usleep(100); }while (!fl ...

  6. Devexpress xaf BO中字段为RuleRequiredField必输字段时,文本标签默认添加*标记

    BO中字段为RuleRequiredField必输字段时,文本标签默认添加*标记.需要在模型编辑器中设置,如图. 官网地址:https://docs.devexpress.com/eXpressApp ...

  7. Flask 卡住, 无响应问题

    自己学习Flask+Gevent, 做了一个小接口服务器, 但在收到请求后, 打印请求的报文, 并返回正确格式, 运行后会出现收到请求消息后,Flask卡住无响应的的问题, 有时候点击ctrl+C才能 ...

  8. R-corrplot相关性绘图,只有你想不到的

    初步接触数据集,探索性分析后,经常需要做一个相关分析,得到各变量间的相关系数以及显著性水平. 本文介绍一下R-corrplot包进行相关可视化展示. 一 数据准备 载入所需的R包,利用公共数据集mtc ...

  9. mysql索引实现原理

    什么是索引: 索引是一种高效获取数据的存储结构,例:hash. 二叉. 红黑. Mysql为什么不用上面三种数据结构而采用B+Tree: 若仅仅是  select * from table where ...

  10. MyEclipse优化攻略搜集

    1 首先内存设置 不会报讨厌的内存溢出out of memory 和 henp space 在 myeclipse.ini把大小调成一样是因为不让myeclipse频繁的换内存区域的大小. #utf8 ...