HDU 1423 Greatest Common Increasing Subsequence(最长公共上升LCIS)
HDU 1423 Greatest Common Increasing Subsequence(最长公共上升LCIS)
http://acm.hdu.edu.cn/showproblem.php?pid=1423
题意:
给你两个数字组成的串a和b,要你求出它们的最长公共严格递增子序列的长度(LCIS).
分析:
首先我们令f[i][j]==x表示是a串的前i个字符与b串的前j个字符构成的且以b[j]结尾的LCIS长度.
当a[i]!=b[j]时:
f[i][j]=f[i-1][j]
当a[i]==b[j]时:
f[i][j]=max(f[i-1][k])+1. 当中 k<j且b[k]<b[j].
假设我们按上述递推公式依次枚举i, j, k 的话,那么时间复杂度就是O(n*m^2)了.
事实上我们仅仅要枚举i, j. 然后我们记录当前的最大f[i-1][k]值就可以(要满足k<j且b[k]<b[j]). 程序实现用到了一个技巧, 即枚举(i,
j)情况时如果a[i]的值与b[j+1]的值是相等的. 那么仅仅要b[j]<a[i]的话, 我们直接更新max=f[i-1][j]就可以. 如果下一轮a[i]==b[j+1], 那么上一轮max保存的值f[i-1][j] 能够肯定j<j+1 且b[j]<a[i]==b[j+1]. (当b[j]变成b[k]也是一样)
怎样输出一个LCIS串呢?
我们首先找到使得f[n][id]取最大值的id. 然后它肯定是由f[n-1][k](k<id且b[k]<b[id]) 构成的. 所以我们仅仅须要往前找到那个f[n-1][k]==f[n][id]-1 且 b[k]<b[id]的值逆序输出就可以.
事实上动态规划的全部输出方案的问题都能够这么输出.
假设想输出字典序最小的LCIS串呢?
我们仅仅须要将原来的两个序列逆转,然后找出最长公共递减子序列. 然后从第一个LCDS的字符開始找尽可能字典序小的字符就可以. 事实上思想大致都是一样的.
AC代码:
</pre><pre name="code" class="cpp">#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=500+5; int n;//a串长
int m;//b串长
int a[maxn];//a串
int b[maxn];//b串
int f[maxn][maxn]; int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
scanf("%d",&m);
for(int i=1;i<=m;i++)
scanf("%d",&b[i]); memset(f,0,sizeof(f));
for(int i=1;i<=n;i++)
{
int max=0;//当前f[i-1][k]最大值且 k<j&&b[k]<b[j]
int flag=-1;
for(int j=1;j<=m;j++)
{
f[i][j]=f[i-1][j];
if(a[i]>b[j] && max<f[i-1][j])
{
max=f[i-1][j];
flag=j;
}
if(a[i]==b[j])
{
f[i][j]=max+1;
}
}
} int max_val=0;
int id=-1;
for(int i=1;i<=m;i++)
{
if(max_val<f[n][i])
{
max_val=f[n][i];
id=i;
}
} printf("%d\n",max_val);
if(T) printf("\n"); //逆序输出一个LCIS串
/*
int i=n;
while(id!=-1 && f[i][id]>=1)
{
printf("%d ",b[id]);
int tmp=f[i][id];
int tmp_v=b[id];
//往前找到合法的f[i-1][k]
while(id!=0)
{
id--;
if(f[i-1][id]==tmp-1 && b[id]<tmp_v)
break;
}
i--;
}
printf("\n");
*/ }
return 0;
}
HDU 1423 Greatest Common Increasing Subsequence(最长公共上升LCIS)的更多相关文章
- HDU 1423 Greatest Common Increasing Subsequence(LICS入门,只要求出最长数)
Greatest Common Increasing Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536 ...
- HDU 1423 Greatest Common Increasing Subsequence LCIS
题目链接: 题目 Greatest Common Increasing Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: ...
- HDU 1423 Greatest Common Increasing Subsequence(LCIS)
Greatest Common Increasing Subsequenc Problem Description This is a problem from ZOJ 2432.To make it ...
- HDU 1423 Greatest Common Increasing Subsequence
最长公共上升子序列 LCIS 看这个博客 http://www.cnblogs.com/nuoyan2010/archive/2012/10/17/2728289.html #include&l ...
- HDU 1423 Greatest Common Increasing Subsequence ——动态规划
好久以前的坑了. 最长公共上升子序列. 没什么好说的,自己太菜了 #include <map> #include <cmath> #include <queue> ...
- HDOJ 1423 Greatest Common Increasing Subsequence 【DP】【最长公共上升子序列】
HDOJ 1423 Greatest Common Increasing Subsequence [DP][最长公共上升子序列] Time Limit: 2000/1000 MS (Java/Othe ...
- HDOJ 1423 Greatest Common Increasing Subsequence -- 动态规划
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1423 Problem Description This is a problem from ZOJ 2 ...
- POJ 1423 Greatest Common Increasing Subsequence【裸LCIS】
链接: http://acm.hdu.edu.cn/showproblem.php?pid=1423 http://acm.hust.edu.cn/vjudge/contest/view.action ...
- HDUOJ ---1423 Greatest Common Increasing Subsequence(LCS)
Greatest Common Increasing Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536 ...
随机推荐
- perl 调用按钮输出到文本框
sub push_b4 { #$txt -> insert('end'); #select $txt; system("expect c:\\\\expect.txt >expe ...
- libevent evbuffer bug
今天发现 libevent 2.0.22 一个坑爹的bug,导致消息混乱.查找问题浪费一天,复现代码如下 #include <event2/buffer.h> #include <s ...
- Google map v3 using simple tool file google.map.util.js v 1.1
/** * GOOGLE地图开发使用工具 * @author BOONYACHENGDU@GMAIL.COM * @date 2013-08-23 * @notice 地图容器的z-index不能小于 ...
- poj1050(nyoj104 zoj1074)dp问题
To the Max Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 39913 Accepted: 21099 Desc ...
- 【UNIX网络编程(二)】基本TCP套接字编程函数
基于TCP客户/server程序的套接字函数图例如以下: 运行网络I/O.一个进程必须做的第一件事就是调用socket函数.指定期望的通信协议类型. #include <sys/socket.h ...
- 设计师Yoyo:为用户设计产品,让他们生活更美好
Yoyo设计走过的路:纽约爱立信,西雅图美国在线,硅谷雅虎,ATT,深圳腾讯,华为:Yoyo不仅是顶级的交互体验设计师,还是很Open的知识分享者,从职业选择,以及对年轻人的建议几个角度,摘录他的文章 ...
- Android自己主动化測试之Monkeyrunner用法及实例
眼下android SDK里自带的现成的測试工具有monkey 和 monkeyrunner两个.大家别看这俩兄弟名字相像,但事实上是完全然全不同的两个工具,应用在不同的測试领域.总的来说,monke ...
- 图像、帧、片、NALU概念理解
图像.帧.片.NALU 是学习 H.264 的人常常感到困惑的一些概念. H.264 是一次概念的革新,它打破常规,完全没有 I 帧.P帧.B 帧的概念,也没有 IDR 帧的概念.对于 H.264 中 ...
- SQL Server DML(UPDATE、INSERT、DELETE)常见用法(一)
1.引言 T-SQL(Transact Structured Query Language)是标准的SQL的扩展,是程序和SQL Server沟通的主要语言. T-SQL语言主要由以下几部分组成: 数 ...
- Excel导入sq server后数据列以科学计数法显示
一.选中excel数据列如图 二.选择数据--分列 三.选择下一步,下一步,文本 四.完成 五.这样把excel导入到数据库中是以文本形式显示不会出现科学计数法