[SDOI2006]最短距离
声明:
本篇文章只大概讲思路
原串设为$s1$,目标串设为$s2$,$n1,n2$分别为他们的长度
我们考虑$dp$,设$f[i][j]$表示$s1$中删除到了第$i$个字符,$s2$中添加到了第$j$个字符,那么对于每种操作,我们如下转移:
$1、Delete$:(删除操作,不需要判断,直接转移,此时的费用为$s1$删除到$i-1$,$s2$添加到$j$时的费用加上删除的费用并且取最小值)
$f[i][j]=min(f[i][j],f[i-1][j]+pay[1]$
$2、Repalce$:(替换操作,不需要判断,直接转移,此时的费用为$s1$删除到$i-1$,$s2$添加到$j-1$时的费用加上费用取最小值)
$f[i][j]=min(f[i][j],f[i-1][j-1]+pay[2])$
$3、Copy$:(复制操作,需要判断,当现在的$i,j$相同时转移)
$if(s1[i]==s2[j])
f[i][j]=min(f[i][j],f[i-1][j-1]+pay[3]);$
$4、Insert$:(插入操作,不需要判断,直接转移)
$f[i][j]=min(f[i][j],f[i][j-1]+pay[4])$
$5、Twiddle$:(需要判断,当$i>=2\&\&j>=2\&\&s1[i-1]==s2[j]\&\&s1[i]==s2[j-1]$的时候转移)
$if(i>=2\&\&j>=2\&\&s1[i-1]==s2[j]\&\&s1[i]==s2[j-1])$
$f[i][j]=min(f[i][j],f[i-2][j-2]+pay[5])$
$6、Kill$:(单独拿出来用,最后判断一下)
$for(int i=1;i<n1;++i)$
$f[n1][n2]=min(f[n1][n2],f[i][n2]+(n1-i)*pay[1]-1)$
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
#define N 210
#define inf 0x3f3f3f3f
using namespace std;
char s1[N],s2[N];
int n1,n2;
int pay[6],f[N][N];//f[i][j]中i表示s1中已经删除到i个字符,j表示s2串中已经添加到j个字符
int main()
{
scanf(" %s %s",s1+1,s2+1);
n1=strlen(s1+1),n2=strlen(s2+1);
for(int i=1;i<=5;++i)
scanf("%d",&pay[i]);
for(int i=1;i<=n1;++i)
for(int j=1;j<=n2;++j)
f[i][j]=inf;
for(int i=1;i<=n1;++i)
f[i][0]=pay[1]*i;
for(int i=1;i<=n2;++i)
f[0][i]=pay[4]*i;
f[0][0]=0;
for(int i=1;i<=n1;++i)
{
for(int j=1;j<=n2;++j)
{
if(s1[i]==s2[j])
f[i][j]=min(f[i][j],f[i-1][j-1]+pay[3]);
f[i][j]=min(f[i][j],f[i-1][j]+pay[1]);
f[i][j]=min(f[i][j],f[i][j-1]+pay[4]);
f[i][j]=min(f[i][j],f[i-1][j-1]+pay[2]);
if(i>=2&&j>=2&&s1[i-1]==s2[j]&&s1[i]==s2[j-1])
f[i][j]=min(f[i][j],f[i-2][j-2]+pay[5]);
}
}
for(int i=1;i<n1;++i)
f[n1][n2]=min(f[n1][n2],f[i][n2]+(n1-i)*pay[1]-1);
printf("%d",f[n1][n2]);
}
[SDOI2006]最短距离的更多相关文章
- P2453 [SDOI2006]最短距离
题目描述 一种EDIT字母编辑器,它的功能是可以通过不同的变换操作可以把一个源串X [l..m]变换为新的目标串y[1..n].EDIT提供的变换操作有: 源串中的单个字符可被删除(delete): ...
- P2453 [SDOI2006]最短距离 dp
自己想出来了!这个dp比较简单,而且转移也很简单,很自然,直接上代码就行了. 题干: 一种EDIT字母编辑器,它的功能是可以通过不同的变换操作可以把一个源串X [l..m]变换为新的目标串y[1..n ...
- 点(x3,y3)到经过点(x1,y1)和点(x2,y2)的直线的最短距离
/// <summary> /// 点(x3,y3)到经过点(x1,y1)和点(x2,y2)的直线的最短距离 /// </summary> /// <param name ...
- [ACM_几何] The Deadly Olympic Returns!!! (空间相对运动之最短距离)
http://acm.hust.edu.cn/vjudge/contest/view.action?cid=28235#problem/B 题目大意: 有两个同时再空间中匀速运动的导弹,告诉一个时间以 ...
- 求DAG上两点的最短距离
Problem 给出一个不带边权(即边权为1)的有向无环图(unweighted DAG)以及DAG上两点s, t,求s到t的最短距离,如果无法从s走到t,则输出-1. Solution DFS,BF ...
- HDU 2083 简易版之最短距离 --- 水题
HDU 2083 简易版之最短距离 /* HDU 2083 简易版之最短距离 */ #include <cstdio> #include <algorithm> using n ...
- codeforces 590C C. Three States(bfs+连通块之间的最短距离)
题目链接: C. Three States time limit per test 5 seconds memory limit per test 512 megabytes input standa ...
- hdoj 2083 简易版之最短距离
简易版之最短距离 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- [LeetCode]Word Ladder 最短距离字符串转换 (Dijkstra)
要求最短距离.采纳dijkstra查找节点之间的最短路径. 当心:假设是一个枚举字典22是否元素可以,如果转换,暂停. 提高:每串,带您历数它的字符值事件,对于的长度n一个字符串枚举n*26次要. 设 ...
随机推荐
- Go语言学习之斐波那契数列的测试例子和定义常量方法
### Go语言学习之斐波那契数列的测试例子和定义常量方法 1.go语言中测试文件必须以test.go结尾,比如:fib_test.go 2.测试文件内的方法必须是Test开头,比如:func Tes ...
- 【bitset】Kth Minimum Clique
#include<bits/stdc++.h> #define B bitset<105> using namespace std; typedef long long ll ...
- 移动端测试之APP安全测试
现在APP测试已经是测试行业的一个重要分支,对APP测试技能和经验的要求也越来越高,看到一篇关于APP安全测试的总结,分享给需要的朋友.1.软件权限1)扣费风险:包括发送短信.拨打电话.连接网络等2) ...
- Java基础之IO和NIO补完
Java Stream,File,IO 关于NIO和IO的比较,参考:Java NIO系列教程(十二) Java NIO与IO java包之java.io 参考材料:菜鸟教材 NIO 由于下面的系列教 ...
- MySQL 索引的优化
一.MySQL如何使用索引(index) 1.1 索引概述 索引用于快速查找具有特定列值的行. 如果不使用索引,MySQL必须从表的第一行开始,然后扫描整个表来寻找符合条件的行.这种情况下,表越大,扫 ...
- 解决npm ERR!Unexpected end of JSON input while paring near (解析附近时JSON输入意外结束)'...."^2.0.0-rc.0","glob"'等npm install错误
摘要 最近更新了一次node,但是更新后npm的命令总是会报 npm WARN deprecated fsevents@2.0.6: Please update: there are crash fi ...
- vue组件之间的传值
vue中组件之间的传值有好几种情况 1.父向子传值 父组件向子组件传值使用props,直接上实例 city.vue是父组件,list.vue是子组件city.vue里定义cities和hotCitie ...
- C++ STL 之 set 和 pair
set/multiset 的特性是所有元素会根据元素的值自动进行排序.set 是以 RB-tree(红黑树,平衡二叉树的一种)为底层机制,其查找效率非常好.set 容器中不允许重复元 素,multis ...
- vue常用知识点
vue中图片路径写法 <img :src="avatorSrc" alt=""> <img :src="avatorSrc2&quo ...
- OpenCV入门学习资料汇总
OpenCV学习文档资料 OpenCV学习:1)OpenCV中文网站——http://wiki.opencv.org.cn/index.php/%E9%A6%96%E9%A1%B5 2)python实 ...