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)的更多相关文章

  1. HDU 1423 Greatest Common Increasing Subsequence(LICS入门,只要求出最长数)

    Greatest Common Increasing Subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536 ...

  2. HDU 1423 Greatest Common Increasing Subsequence LCIS

    题目链接: 题目 Greatest Common Increasing Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: ...

  3. HDU 1423 Greatest Common Increasing Subsequence(LCIS)

    Greatest Common Increasing Subsequenc Problem Description This is a problem from ZOJ 2432.To make it ...

  4. HDU 1423 Greatest Common Increasing Subsequence

    最长公共上升子序列   LCIS 看这个博客  http://www.cnblogs.com/nuoyan2010/archive/2012/10/17/2728289.html #include&l ...

  5. HDU 1423 Greatest Common Increasing Subsequence ——动态规划

    好久以前的坑了. 最长公共上升子序列. 没什么好说的,自己太菜了 #include <map> #include <cmath> #include <queue> ...

  6. HDOJ 1423 Greatest Common Increasing Subsequence 【DP】【最长公共上升子序列】

    HDOJ 1423 Greatest Common Increasing Subsequence [DP][最长公共上升子序列] Time Limit: 2000/1000 MS (Java/Othe ...

  7. HDOJ 1423 Greatest Common Increasing Subsequence -- 动态规划

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1423 Problem Description This is a problem from ZOJ 2 ...

  8. 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 ...

  9. HDUOJ ---1423 Greatest Common Increasing Subsequence(LCS)

    Greatest Common Increasing Subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536 ...

随机推荐

  1. Linux下将多个静态库(.a)合并成一个静态库文件(.a)的命令操作,方法一

    .a 文件的结构和.tar文件就没有什么区别. x 命令解出来, a 命令添加, t命令列表 假设A.a, B.a C.a 在/usr/local/lib目录下 mkdir /tmp/libABC c ...

  2. 使用Kotlin开发Android应用(I):简单介绍

    使用Kotlin开发Android应用(I):简单介绍 @author ASCE1885的 Github 简书 微博 CSDN 原文链接 Kotlin是一门基于JVM的编程语言.它正成长为Androi ...

  3. springMVC3学习(四)--訪问静态文件如js,jpg,css

    假设你的DispatcherServlet拦截的是*.do这种URL.就不存在訪问不到静态资源的问题 假设你的DispatcherServlet拦截了"/"全部的请求,那同一时候对 ...

  4. C / C++算法学习笔记(8)-SHELL排序

    原始地址:C / C++算法学习笔记(8)-SHELL排序 基本思想 先取一个小于n的整数d1作为第一个增量(gap),把文件的全部记录分成d1个组.所有距离为dl的倍数的记录放在同一个组中.先在各组 ...

  5. 如何实现在O(n)时间内排序,并且空间复杂度为O(1)

    对于常见的排序算法,很难做到在O(n)时间内排序,并且空间复杂度为O(1),这里提供了一种方法可以达到要求. 可以使用哈希排序的思想,也就是将所有的数哈希到哈希表中,实现排序.具体的算法思想是,求出这 ...

  6. plaidctf2015 uncorrupt png

    代码的执行时间挺长的,好囧! 参考了https://13c5.wordpress.com/2015/04/20/plaidctf-2015-png-uncorrupt/的代码 通过这个题目,也对Png ...

  7. 【并查集+拓扑排序】【HDU1811】【Rank of Tetris】

    题意:给你3种关系 A=B,A>B,A<B 问是否排名方式唯一,或者存在矛盾 解 1.读入数据先处理 =号 用并查集的祖先作为代表元素,其他儿子节点都等于跟这个点重叠. 再读入 '< ...

  8. linux下的DNS

    Linux下设置DNS的位置主要是, 1网卡设置配置文件里面DNS服务器地址设置;2 hosts文件指定 3.系统默认DNS服务器地址设置/etc/resolv.conf文件修改 生效顺序是: 1 h ...

  9. Redis系列整理

    0.Redis系列-安装部署维护篇 1.Redis系列-远程连接redis并给redis加锁 2.Redis系列-存储篇string主要操作函数小结 3.Redis系列-存储篇list主要操作函数小结 ...

  10. Javascript Number类型常见迷惑点

    1:NaN(Not a Number) 表示一个本来要返回数值的操作数没有返回数值的情况.在ECMAscript中,任何数除以0会返回NaN[ps:实际上只有0/0会返回NaN],正(负)数除以0会返 ...