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 ...
随机推荐
- HUAWEI HiAI亮相Droidcon柏林2018开发者峰会 开启HiAI海外生态
柏林时间6月25日到27日,华为HiAI亮相Droidcon柏林2018开发者峰会,有1200多位海外开发者参加了此次峰会,来自HUAWEI HiAI领域的多名专家携手Prisma和金山WPS,以“E ...
- centos 6.9使用Rsync+Inotify-tools实现数据实时同步
centos 6.9使用Rsync+Inotify-tools实现数据实时同步 说明: 操作系统:CentOS 6.9 源服务器:192.168.1.222 备份服务器:192.168.1.1.233 ...
- 【Mysql】之视图操作
一.视图实例1-创建视图及查询数据操作 首先,创建三个表:user.course.user_course 表:user CREATE TABLE `user` ( `id` ) NOT NULL AU ...
- 探究 Redis 4 的 stream 类型
redis 2 10 月初,Redis 搞了个大新闻.别紧张,是个好消息:Redis 引入了名为 stream 的新数据类型和对应的命令,大概会在年底正式发布到 4.x 版本中.像引入新数据类型这样的 ...
- SQL索引及表的页的逻辑顺序与物理顺序
1.经过测试发现当聚集索引新建或者重建时,会按照逻辑顺序重新排列数据页和数据页内的数据行的物理顺序. 2.但修改表时,无论是聚集索引还是堆的数据页都是按自然顺序向后插入数据,页面上的偏移量可以证明.因 ...
- Android自定义action与permission!!! (转)
原文地址:http://blog.csdn.net/android_tutor/article/details/6310418#reply 大家好,今天给大家简单分享一下Android中自定义acti ...
- WEBserver、应用程序server、HTTPserver差别
WEBserver.应用程序server.HTTPserver差别 WEBserver.应用程序server.HTTPserver有何差别?IIS.Apache.Tomcat.Weblogic.Web ...
- JAVA读文件和写文件的的代码模版
有的时候经常为真么读写文件最合理发愁,因为JAVA提过读写文件的方式太多了(C更甚至,fopen & open又有多少人傻傻分不去,更别说ReadFile了). 这里个人绝对比较好的写法,仅供 ...
- wxwidget自定义消息处理步骤
from http://www.cppblog.com/kenlistian/archive/2009/02/06/73096.html 略有修改 wxwidget自定义消息处理步骤 自定义消息处理( ...
- tomcat 编码问题
默认情况下,tomcat使用的的编码方式:iso8859-1 修改tomcat下的conf/server.xml文件 找到如下代码: < Connector port="8080 ...