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

分析: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. 六:ZooKeeper的java客户端api的使用

    一:客户端链接测试 package com.yeepay.sxf.createConnection; import java.io.IOException; import org.apache.zoo ...

  2. 亲测能用的mysqli类,挺好用的

    <?php header('content-type:text/html;charset=utf-8'); /* 掌握满足单例模式的必要条件 (1)私有的构造方法-为了防止在类外使用new关键字 ...

  3. AC日记——文化之旅 洛谷 P1078

    文化之旅 思路: 暴搜,倒搜: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 105 #define max ...

  4. ubuntu16.04编译安装GPAC

    参考:http://blog.csdn.net/tianlong_hust/article/details/9273875 1.获取gpac的源代码 sudo apt-get install subv ...

  5. C++ 取整数学函数

    C++ 取整数学函数 将浮点数取整或者四舍五入的数据处理情况经常见到,下面做一下总结. 注意:函数取整返回值均为 double 型,在用 printf 输出时应注意. 数学头文件 #include&l ...

  6. 跨域请求httpclient

    httpclient:是Apache工具包,util,它可以作为一个爬虫,直接爬取某个互联网上的页面.获取到时页面最终的源文件html.直接可以获取页面返回json.就可以直接在代码内部模拟发起htt ...

  7. ajax向php传参数对数据库操作

    刚入门php,要求要对多用户进行批量删除(当然实际中是不可能的),在这就以此为例. 大意就是通过对数据库中用户查询,将用户信息显示在页面表格中,在进行多项选择后将所选行参数通过ajax传入后台php文 ...

  8. HDU 6463.超级无敌简单题-卡边界的暴力 (“字节跳动-文远知行杯”广东工业大学第十四届程序设计竞赛)

    超级无敌简单题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  9. 线段树+哈希【CF580E】Kefa and Watch

    线段树+哈希[CF580E]Kefa and Watch Description \(n\)个数的字符串,\(m + k\)个操作 1 l r k把\(l - r\)赋值为\(k\) 2 l r d询 ...

  10. Arduino可穿戴开发入门教程LilyPad介绍

    Arduino可穿戴开发入门教程LilyPad介绍 Arduino输出模块 LilyPad官方共提供了4种输出模块,他们分别是单色LED模块(图1.5).三色LED模块(图1.6).蜂鸣器模块(图1. ...