题目:编辑距离。给你两个串,将已知串转化成目标串,能够增、删、改字母,求最小操作次数。

分析:dp,编辑距离。同最大公共子序列。

注意操作位置是实时变化的。

(前面都已经处理好了)

                     f[i][j] = f[i-1][j]         这时删掉 str1[i],位置j+1。

                     f[i][j] = f[i][j-1]         这时添加 str2[j]。位置j;

                     f[i][j] = f[i-1][j-1]+k  假设str1[i] == str2[j]这时同样k=0,否则k=1,位置j。

说明:注意是str1变成str2;变化位置是这一步时所在的位置(前面的都处理过了)。

#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio> char str1[24],str2[24];
int dp[24][24],op[24][24]; void output( int i, int j )
{
if ( !i && !j ) return;
if ( op[i][j] == 1 ) {
output( i-1, j );
printf("D%c%02d",str1[i-1],j+1);
}else if ( op[i][j] == 2 ) {
output( i, j-1 );
printf("I%c%02d",str2[j-1],j);
}else if ( op[i][j] == 3 ){
output( i-1, j-1 );
printf("C%c%02d",str2[j-1],j);
}else output( i-1, j-1 );
} int main()
{
while ( scanf("%s",str1) && str1[0] != '#' ) {
scanf("%s",str2);
int l1 = strlen(str1);
int l2 = strlen(str2);
for ( int i = 0 ; i <= l1 ; ++ i )
for ( int j = 0 ; j <= l2 ; ++ j ) {
dp[i][j] = 400;
op[i][j] = 0;
} //初始化
for ( int i = 0 ; i <= l1 ; ++ i ) {
op[i][0] = 1; dp[i][0] = i;
}
for ( int i = 0 ; i <= l2 ; ++ i ) {
op[0][i] = 2; dp[0][i] = i;
} for ( int i = 1 ; i <= l1 ; ++ i )
for ( int j = 1 ; j <= l2 ; ++ j ) {
if ( str1[i-1] != str2[j-1] ) {
op[i][j] = 3; dp[i][j] = dp[i-1][j-1]+1;
}else dp[i][j] = dp[i-1][j-1];
if ( dp[i-1][j]+1 < dp[i][j] ) {
op[i][j] = 1; dp[i][j] = dp[i-1][j]+1;
}
if ( dp[i][j-1]+1 < dp[i][j] ) {
op[i][j] = 2; dp[i][j] = dp[i][j-1]+1;
}
}
output( l1, l2 );
printf("E\n");
}
return 0;
}

UVa 164 - String Computer的更多相关文章

  1. 区间DP UVA 10739 String to Palindrome

    题目传送门 /* 题意:三种操作,插入,删除,替换,问最少操作数使得字符串变成回文串 区间DP:有一道类似的题,有点不同的是可以替换,那么两端点不同的时候可以替换掉一个后成回文, 即dp[j+1][k ...

  2. 区间DP UVA 1351 String Compression

    题目传送门 /* 题意:给一个字符串,连续相同的段落可以合并,gogogo->3(go),问最小表示的长度 区间DP:dp[i][j]表示[i,j]的区间最小表示长度,那么dp[i][j] = ...

  3. UVA 1351 - String Compression

    题意: 对于一个字符串中的重复部分可以进行缩写,例如"gogogo"可以写成"3(go)",从6个字符变成5个字符.."nowletsgogogole ...

  4. UVA 10739 String to Palindrome(动态规划 回文)

    String to Palindrome 题目大意:给出一个字符串s,现在可以进行3种操作(添加字母,删除字母,替换字母),将其变成回文串,求出最少的操作次数.比如abccda,可以用删除操作,删除b ...

  5. UVA 10739 String to Palindrome(dp)

    Problem H String to Palindrome Input: Standard Input Output: Standard Output Time Limit: 1 Second In ...

  6. EOJ 1641/UVa The SetStack Computer

    Background from Wikipedia: “Set theory is a branch of mathematics created principally by the German ...

  7. UVa 908 - Re-connecting Computer Sites

    题目大意:有n个网站,由m条线路相连,每条线路都有一定的花费,找出连接所有线路的最小花费. 最小生成树问题(Minimal Spanning Tree, MST),使用Kruskal算法解决. #in ...

  8. 一位学长的ACM总结(感触颇深)

    发信人: fennec (fennec), 信区: Algorithm 标 题: acm 总结 by fennec 发信站: 吉林大学牡丹园站 (Wed Dec 8 16:27:55 2004) AC ...

  9. jquery 、 JS 脚本参数的认识与使用

    jquery . JS 脚本参数的认识与使用 如何使用jquery刷新当前页面 下面介绍全页面刷新方法:有时候可能会用到 window.location.reload(); //刷新当前页面. par ...

随机推荐

  1. OpenCL与CUDA,CPU与GPU

    OpenCL OpenCL(全称Open Computing Language,开放运算语言)是第一个面向异构系统通用目的并行编程的开放式.免费标准,也是一个统一的编程环境,便于软件开发人员为高性能计 ...

  2. win10更换登陆背景和关闭锁屏

    更换登陆背景图 用国外一个hacker写的工具,可在github上下载,或者下载我上传到百度网盘的备份.win10默认的登陆背景太难看了. 去掉锁屏图片 登陆界面其实本身就是一种锁屏,为什么还要单独搞 ...

  3. [译]怎样在Vue.js中使用jquery插件

    原文:http://gambardella.info/2016/09/05/guide-how-to-use-vue-js-with-jquery-plugins 使用Vue真的太棒了,但是也有可能使 ...

  4. Foxmail 登录 qq 账号时无法登录 提示我们设置了独立密码或使用授权码登录的解决方法

    Foxmail 登录 qq 账号时无法登录  提示我们设置了独立密码或使用授权码登录的解决方法 1.首先我们设置我们邮箱的类型如下图所示 2.打开网页版的qq邮箱  在设置--->账户---&g ...

  5. IO复用之epoll系列

    epoll是什么? epoll是Linux内核为处理大批量文件描述符而作了改进的poll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的 ...

  6. php导出excel时间错误(同一个时间戳,用date得到不同的时间)

    通过在date之前设置时区解决了 date_default_timezone_set("Asia/Shanghai"); $schedule_time = date("Y ...

  7. 19. Remove Nth Node From End of List【Medium】【删除单链表倒数第n个结点】

    Given a linked list, remove the n-th node from the end of list and return its head. Example: Given l ...

  8. HttpClient不同版本超时时间的设置

    引自 https://www.cnblogs.com/hisunhyx/p/5028391.html 3.X是这样的 HttpClient client=new DefaultHttpClient() ...

  9. Compass用法

    一.什么是Compass? Compass是Sass的工具库,Compass在SASS的基础上,封装了一系列有用的模块去补充Sass的功能,类似Javascript和jQuery 二.安装 之前已经写 ...

  10. JDBC 编程工具包

    工具包结构 工具包代码 BeanCountHander.java import java.sql.ResultSet; public class BeanCountHander implements ...