hdu1503 LCS
题意:如果有相同的字母,这些字母只输出一次。其余的都输出。
先做一次LCS,标记相同的字母,然后回溯输出。
#include<stdio.h>
#include<string.h>
#define maxn 110
char s1[maxn],s2[maxn];
int dp[maxn][maxn],map[maxn][maxn],len1,len2;
void LCS()
{
int i,j;
for(i=;i<=len1;i++)
for(j=;j<=len2;j++)
{
if(s1[i]==s2[j])
{
dp[i][j]=dp[i-][j-]+;
map[i][j]=;
}
else if(dp[i][j-]>dp[i-][j])//标记公共字串的母串,即公共串从哪个串来,
{ //这样回溯的时候就能不改变顺序。
dp[i][j]=dp[i][j-];
map[i][j]=;
}
else
{
dp[i][j]=dp[i-][j];
map[i][j]=-;
}
}
}
void print(int i,int j)
{
if(i==&&j==)return;
if(i==){
print(i,j-);printf("%c",s2[j]);
}
else if(j==){
print(i-,j);printf("%c",s1[i]);
}
else if(map[i][j]==){//是相同的字母 只输出一次
print(i-,j-);printf("%c",s1[i]);
}
else if(map[i][j]>){
print(i,j-);printf("%c",s2[j]);
}
else {
print(i-,j);printf("%c",s1[i]);
}
}
int main()
{
int i,j;
while(scanf("%s%s",s1,s2)!=EOF)
{
memset(dp,,sizeof(dp));
memset(map,,sizeof(map)); len1=strlen(s1);
len2=strlen(s2); /*for(i=0;i<=len1;i++)//这里主要为了防止出现负值,在i或j为0时使用
map[i][0]=-1;
for(i=0;i<=len2;i++)
map[0][i]=1;*/ for(i=len1;i>;i--)
s1[i]=s1[i-];
for(i=len2;i>;i--)
s2[i]=s2[i-];
LCS();//求一次公共字串 标记相同的串 相同串只需要输出一次
print(len1,len2);
puts("");
}
}
LCS的题目基本上就是一个类型加上变换。dp[i][j]表示到目前为止的公共最大长度。
如果 s[i]==s[j] dp[i][j]可以从dp[i-1][j-1]+1得到;
不然的话就是max(dp[i-1][j],dp[i][j-1]);
因为从一开始就是最优的,所以dp[i-1][j],dp[i][j-1]放了当前不满足条件的时候的前几个以求出的值。
hdu1503 LCS的更多相关文章
- HDU1503(LCS,记录路径)
Advanced Fruits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- HDU1503:Advanced Fruits(LCS)
Problem Description The company "21st Century Fruits" has specialized in creating new sort ...
- 我的第一篇博客----LCS学习笔记
LCS引论 在这篇博文中,博主要给大家讲一个算法----最长公共子序列(LCS)算法.我最初接触这个算法是在高中学信息学竞赛的时候.那时候花了好长时间理解这个算法.老师经常说,这种算法是母算法,即从这 ...
- 动态规划之最长公共子序列(LCS)
转自:http://segmentfault.com/blog/exploring/ LCS 问题描述 定义: 一个数列 S,如果分别是两个或多个已知数列的子序列,且是所有符合此条件序列中最长的,则 ...
- 动态规划求最长公共子序列(Longest Common Subsequence, LCS)
1. 问题描述 子串应该比较好理解,至于什么是子序列,这里给出一个例子:有两个母串 cnblogs belong 比如序列bo, bg, lg在母串cnblogs与belong中都出现过并且出现顺序与 ...
- Hackerrank11 LCS Returns 枚举+LCS
Given two strings, a and , b find and print the total number of ways to insert a character at any p ...
- UVA 11404 Palindromic Subsequence[DP LCS 打印]
UVA - 11404 Palindromic Subsequence 题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串 不要求路径区间DP都可以做 然而要字典序最小 倒过来求L ...
- 删除部分字符使其变成回文串问题——最长公共子序列(LCS)问题
先要搞明白:最长公共子串和最长公共子序列的区别. 最长公共子串(Longest Common Substirng):连续 最长公共子序列(Longest Common Subsequence,L ...
- 最大公共字串LCS问题(阿里巴巴)
给定两个串,均由最小字母组成.求这两个串的最大公共字串LCS(Longest Common Substring). 使用动态规划解决. #include <iostream> #inclu ...
随机推荐
- Eureka自我保护机制、健康检查的作用、actuator模块监控
在上一篇文章微服务入门之服务的注册以及服务之间的调用中,我们基本实现了服务之间的调用,今天我们来了解一下Eureka自我保护机制以及健康检查. Eureka自我保护机制 接着以上篇文章建立的三个工程为 ...
- VS中warning MSB8004和error MSB4018解决方案
问题如下: warning MSB8004: Output Directory does not end with a trailing slash. This build instance wil ...
- JasperReports报表变量13
报表变量是建立在报表表达式之上的特殊对象.报表变量简化以下任务: 报表,其中大量使用在整个报告模板表达式.这些表达式可以通过使用报表变量只能声明一次. 计数,求和,平均,最低,最高,方差等:报表变量可 ...
- Sql Server实现自动增长
在学习中遇到这个问题 数据库里有编号字段 BH00001 BH00002 BH00003 BH00004 如何实现自动增长 --下面的代码生成长度为8的编号,编号以BH开头,其余6位为流水号. --得 ...
- 请问Pycharm如何实现变量的批量重命名?
1.点击你要改的单词,右键refactor ->rename 2. Ctrl + R 替换 Ctrl + Shift + F 全局查找 Ctrl + Shift + R 全局替换
- pytorch dataloader 取batch_size时候 出现bug
1.RuntimeError: invalid argument 0: Sizes of tensors must match except in dimension 0. Got 342 and 2 ...
- Luogu P1963 [NOI2009]变换序列(二分图匹配)
P1963 [NOI2009]变换序列 题意 题目描述 对于\(N\)个整数\(0,1, \cdots ,N-1\),一个变换序列\(T\)可以将\(i\)变成\(T_i\),其中\(T_i \in ...
- C#多线程之间事件通知
我有两个线程,线程1接受网络数据,存到队列;线程2取队列,进行各种复杂的处理然后绘制到界面上;想让线程1有数据了通知线程2,线程2再取队列,因为不通知的话,线程2一直在while循环检索队列时候有东西 ...
- ubuntu 安装 go 编译环境
参考: http://wiki.ubuntu.org.cn/Golang 从仓库安装(apt-get) sudo apt-get install golang 修改环境变量: vim /etc/env ...
- C# params 用法简介
params 是C#的关键字, params主要是在声明方法时参数类型或者个数不确定时使用,关于params 参数数组,需掌握以下几点: 一.参数数组必须是一维数组 二.不允许将params修饰符与r ...