hdu 1503 Advanced Fruits(最长公共子序列)
Advanced Fruits
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 3340 Accepted Submission(s): 1714
Special Judge
A big topic of discussion inside the company is "How should the new creations be called?" A mixture between an apple and a pear could be called an apple-pear, of course, but this doesn't sound very interesting. The boss finally decides to use the shortest string that contains both names of the original fruits as sub-strings as the new name. For instance, "applear" contains "apple" and "pear" (APPLEar and apPlEAR), and there is no shorter string that has the same property.
A combination of a cranberry and a boysenberry would therefore be called a "boysecranberry" or a "craboysenberry", for example.
Your job is to write a program that computes such a shortest name for a combination of two given fruits. Your algorithm should be efficient, otherwise it is unlikely that it will execute in the alloted time for long fruit names.
Input is terminated by end of file.
ananas banana
pear peach
bananas
pearch
#include<stdio.h>
#include<string.h> const int maxn=; char str1[maxn],str2[maxn];
int dp[maxn][maxn],len; //len指示ans的长度 struct node{
int i,j; //i记录主串位置,j记录副串当前字符位置
char ch; //记录当前字符
}ans[maxn]; int max(int a,int b){
return a>b?a:b;
} void LCS(int m,int n){
memset(dp,,sizeof(dp));
int i,j;
for(i=;i<=m;i++)
for(j=;j<=n;j++)
if(str1[i]==str2[j])
dp[i][j]=dp[i-][j-]+;
else
dp[i][j]=max(dp[i-][j],dp[i][j-]);
if(dp[m][n]==){ //如果没有公共序列,直接输出
printf("%s%s",str1,str2);
}else{
i=m;j=n;
len=;
while(i!= && j!=){ //取出最长公共子序列的字母
if((dp[i][j]==dp[i-][j-]+) && str1[i]==str2[j]){
ans[len].i=i;
ans[len].j=j;
ans[len++].ch=str1[i]; //倒序保存最长公共子序列字母
i--;j--;
}else if(dp[i-][j]>dp[i][j-])
i--;
else
j--;
}
}
} int main(){ //freopen("input.txt","r",stdin); int len1,len2,i,j,k;
while(scanf("%s%s",str1+,str2+)!=EOF){
len1=strlen(str1+);
len2=strlen(str2+);
LCS(len1,len2);
i=j=;
for(k=len-;k>=;k--){
while(i!=ans[k].i){
printf("%c",str1[i]);
i++;
}
while(j!=ans[k].j){
printf("%c",str2[j]);
j++;
}
printf("%c",ans[k].ch);
i++;j++;
}
printf("%s%s\n",str1++ans[].i,str2++ans[].j);
}
return ;
}
根据LCS的原理,将每个字符都进行标记,看两个字符串中对应的字符究竟处于什么状态,然后输出,其标记为公共子串的字符只输出一次即可
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std; char s1[],s2[];
int len1,len2,dp[][],mark[][]; void LCS()
{
int i,j;
memset(dp,,sizeof(dp));
for(i = ;i<=len1;i++)
mark[i][] = ;
for(i = ;i<=len2;i++)
mark[][i] = -;
for(i = ; i<=len1; i++)
{
for(j = ; j<=len2; j++)
{
if(s1[i-]==s2[j-])
{
dp[i][j] = dp[i-][j-]+;
mark[i][j] = ;
}
else if(dp[i-][j]>=dp[i][j-])
{
dp[i][j] = dp[i-][j];
mark[i][j] = ;
}
else
{
dp[i][j] = dp[i][j-];
mark[i][j] = -;
}
}
}
} void PrintLCS(int i,int j)
{
if(!i && !j)
return ;
if(mark[i][j]==)
{
PrintLCS(i-,j-);
printf("%c",s1[i-]);
}
else if(mark[i][j]==)//根据回溯的位置进行输出
{
PrintLCS(i-,j);
printf("%c",s1[i-]);
}
else
{
PrintLCS(i,j-);
printf("%c",s2[j-]);
}
} int main()
{
while(~scanf("%s%s",s1,s2))
{
len1 = strlen(s1);
len2 = strlen(s2);
LCS();
PrintLCS(len1,len2);
printf("\n");
} return ;
}
hdu 1503 Advanced Fruits(最长公共子序列)的更多相关文章
- hdu 1503 Advanced Fruits 最长公共子序列 *
Advanced Fruits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU 1159 Common Subsequence 最长公共子序列
HDU 1159 Common Subsequence 最长公共子序列 题意 给你两个字符串,求出这两个字符串的最长公共子序列,这里的子序列不一定是连续的,只要满足前后关系就可以. 解题思路 这个当然 ...
- 最长公共子序列(加强版) Hdu 1503 Advanced Fruits
Advanced Fruits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- hdu 1503 Advanced Fruits
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1503 思路:这是一道最长公共子序列的题目,当然还需要记录路径.把两个字符串的最长公共字串记录下来,在递 ...
- HDU 1513 Palindrome(最长公共子序列)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1513 解题报告:给定一个长度为n的字符串,在这个字符串中插入最少的字符使得这个字符串成为回文串,求这个 ...
- hdu 1159 Common Subsequence(最长公共子序列 DP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1159 Common Subsequence Time Limit: 2000/1000 MS (Jav ...
- 题解报告:hdu 1503 Advanced Fruits(LCS加强版)
Problem Description The company "21st Century Fruits" has specialized in creating new sort ...
- HDU 4681 string 求最长公共子序列的简单DP+暴力枚举
先预处理,用求最长公共子序列的DP顺着处理一遍,再逆着处理一遍. 再预处理串a和b中包含串c的子序列,当然,为了使这子序列尽可能短,会以c 串的第一个字符开始 ,c 串的最后一个字符结束 将这些起始位 ...
- hdu 1080 dp(最长公共子序列变形)
题意: 输入俩个字符串,怎样变换使其所有字符对和最大.(字符只有'A','C','G','T','-') 其中每对字符对应的值如下: 怎样配使和最大呢. 比如: A G T G A T G - G ...
随机推荐
- 解决UISlider滑块不灵敏
由于UI给的thumbImage图片过小,默认UISlider开始拖动的手势范围只有thumbImage的大小之内. 为了解决这个问题需要创建一个子类继承于UISlider.重写其中的方法: - (C ...
- java后端技术
技术概论:Springmvc+mybatis+shiro+Dubbo+ZooKeeper+Redis+KafKa j2ee分布式架构 我在恒生工作,主要开发金融互联网第三方平台的对接项目.目前已经对接 ...
- Cobbler部署之FAQ处理
Cobbler报错处理 通过cobbler check检查出现的报错 红色标注为报错关键信息 9.1 报错一 # cobbler check httpd does not appear to be r ...
- PHP中使用POST发送请求的常用方式
前提概要: 在PHP进行项目开发过程中,使用post发送请求的情况很多,以下总结了项目中主要用的两种方式. 总结下: 在我接触到的项目中用到第二种情况较多,比如写:短信接口.....总体来说比较简单便 ...
- thinkphp自动验证无效的问题
新手入门thinkphp,试用自动验证表单输入数据功能,却发现怎么都不能调用自动验证,自动验证无效,原因竟是一个小细节的疏忽,学习一定要细心啊! Action方法: IndexAction下的adds ...
- 【BZOJ2741】【FOTILE模拟赛】L 分块+可持久化Trie树
[BZOJ2741][FOTILE模拟赛]L Description FOTILE得到了一个长为N的序列A,为了拯救地球,他希望知道某些区间内的最大的连续XOR和. 即对于一个询问,你需要求出max( ...
- 自定义弹窗 VS AlertDialog分享弹窗
一.摘要 弹窗通常用于提示用户进行某种操作,比如:点击分享按钮,弹窗分享对话框:双击返回按钮,弹窗退出对话框:下载文件,提示下载对话框等等,分享对话框/退出对话框/下载对话框,都可以直接使用Alert ...
- Swift编程语言学习6—— 闭包
闭包是自包括的函数代码块,能够在代码中被传递和使用. Swift 中的闭包与 C 和 Objective-C 中的代码块(blocks)以及其它一些编程语言中的 lambdas 函数比較类似. 闭 ...
- Android系统字体规范
我们在做Android移动APP设计的时候,字号的选择也是很让人头疼,转载一份有关Android系统字体规范,如果在做Android项目的用户应该看看,如果有任何建议欢迎在留言处与我们交流探讨. 主要 ...
- Python 面试题(下)
接上篇. 网络 1 三次握手 客户端通过向服务器端发送一个SYN来创建一个主动打开,作为三路握手的一部分.客户端把这段连接的序号设定为随机数 A. 服务器端应当为一个合法的SYN回送一个SYN/ACK ...