首页 > 其他分享 >hdu 1516(编辑距离+记录路径)

hdu 1516(编辑距离+记录路径)

时间:2023-05-29 22:38:22浏览次数:45  
标签:tmp hdu int 路径 -- maxn && 1516 dp



最开始把问题搞错了,以为是两个串都可以做修改,无论我怎么想都不通。

回到这个题目上,这道题和最长公共子序列很相似,思路可以说是一样的,包括记录路径。

其实也就是根据递推数组的结果来判断。



#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;

const int maxn = 85;
char A[maxn],B[maxn];
int dp[maxn][maxn],len1,len2;

void path()
{
	int tmp, i = len1, j = len2;
	int step = 0;
	while(i >= 1 || j >= 1)
	{
		if(A[i-1] == B[j-1]) tmp = 0;
		else tmp = 1;
		if(dp[i][j] == dp[i-1][j-1] + tmp && i >= 1 && j >= 1)
		{
			if(tmp)
				printf("%d Replace %d,%c\n",++step,i,B[j-1]);
			i--, j--;
		}
		else if(dp[i][j] == dp[i-1][j] + 1 && i >= 1)
		{
			printf("%d Delete %d\n",++step,i);
			i--;
		}
		else if(dp[i][j] == dp[i][j-1] + 1 && j >= 1)
		{
			printf("%d Insert %d,%c\n",++step,i+1,B[j-1]);
			j--;
		}
	}
}

int main()
{
	while(scanf("%s %s",A,B)!=EOF)
	{
		getchar();
		len1 = strlen(A);
		len2 = strlen(B);
		memset(dp,0,sizeof(dp));
		for(int i = 0; i <= len1; i++)
			dp[i][0] = i;
		for(int i = 0; i <= len2; i++)
			dp[0][i] = i;
		for(int i = 1; i <= len1; i++)
			for(int j = 1; j <= len2; j++)
			{
				int tmp = min(dp[i][j-1],dp[i-1][j]) + 1;
				int d = A[i-1] == B[j-1] ? 0 : 1;
				dp[i][j] = min(tmp,dp[i-1][j-1]+d);
			}
		printf("%d\n",dp[len1][len2]);
		path();
	}
	return 0;
}




标签:tmp,hdu,int,路径,--,maxn,&&,1516,dp
From: https://blog.51cto.com/u_16143128/6374300

相关文章

  • hdu 2473(并查集+删除操作)
    解题思路:这道题有并查集的删除操作,如果直接对这一棵树进行删除节点操作肯定是很困难的。所以可以建立虚拟节点,只要有一个节点要被删除,就直接把它投影到虚拟节点上,即用这个虚拟节点来代替我们要删除的节点。这样我们就不需要用对已有的树形结构进行改动了。这个想法我在DragonBalls......
  • hdu 3635(并查集+路径压缩变形)
    解题思路:这道题想了我好久,因为我把城市的编号一起考虑进去了,结果想了好久都没A,最后看了别人的题解居然都没有考虑到城市的编号,不考虑城市编号的问题的话就是一个很水的并查集了。#include<iostream>#include<cstdio>#include<cstring>usingnamespacestd;constintMAXN=1000......
  • hdu 2874(LCA + 节点间距离)
    解题思路:Tarjan离线处理一篇介绍LCA的很好的博客:http://www.cppblog.com/menjitianya/archive/2015/12/10/212447.html#include<iostream>#include<cstdio>#include<cstring>usingnamespacestd;constintmaxn=10005;structEdge{ intk,next,cost;}edge[maxn&......
  • hdu 4027(线段树)
    题意:给定100000个数,两种操作,0ij表示将ij这段的数字都开根号(向下取整),1ij表示查询ij之间的所有值的和。。。(所有的和都不超过64位)解题思路:这题要做区间的开平方操作,2^64最多可以做8次开平方操作,所以对于每个节点最多只有8次操作,这道题如果lazy思想的话就要保存每个区间被开平方......
  • hdu 3564(线段树+LIS)
    题意:给出1~n的插入顺序,要求每次插入之后的LIS解题思路:这道题确实挺难想的,我最开始想用树状数组每插入一个数就更新一次,如果这么想,那么你就输了。它这里的想法是先将1-n的最终位置都保存起来,然后再一个个去找LIS。这里有点离线算法的意思,至少了解到更新时可以先别急着处理。还有这里......
  • hdu 3874(树状数组+离线算法)
    解题思路:这道题和之前的题一样,查找[l,r]区间内不重复数字的和。可以利用离线算法,实际上离线算法为了解决在查找时出现的矛盾,因为每次询问的区间大小不同,如果单独处理的话可能会对之后的查询有影响,所以离线算法帮助我们把要查询的区间先按照右端点进行排序,因为在处理更靠右的区间时,......
  • hdu 4101(bfs+博弈)
    题意:题目的意思就是说两个人轮流玩游戏,给你一张地图,这个地图中间有一点-1代表宝藏,AliandBaba轮流走路,如果某一个人能够直接走到宝藏的话,那么他就赢了。地图上其它的点0代表空地,数字代表当前地点的石子当某一人拿石子的时候,他只能拿走一颗。问你谁最后能拿到宝藏;解题思路:宝藏位于-......
  • hdu 1510
    WhiteRectanglesTimeLimit:2000/1000MS(Java/Others)    MemoryLimit:65536/32768K(Java/Others)ProblemDescriptionYouaregivenachessboardmadeupofNsquaresbyNsquareswithequalsize.Someofthesquaresarecoloredblack,andthe......
  • hdu 2821
    题意:n*m的格子上有一些方块放在某些格子上,一个格子可能有几个方块,用'a'-'z'来表示方块数量。初始的时候可以选择任意空地作为Pusher初始点,Pusher选择一个方向,然后向这个方向前进直到遇到有方块的格子,Pusher把这个格子的方块清除一个,并把它向前推一格(向前不能出界),如果前面一格有方......
  • hdu 1534(差分约束)
    题意:安排计划,有4种约束方式,给出你这些时间的n个约束..如果计划是可行的,求出每一件事发生的最早时间..否则输出“impossible”..①.FAFaba要在b完成后完成..②.FASaba要在b开始前完成..③.SASaba要在b开始前开始..④.SAFaba要在b结束前开......