链接:hdu 5087

题意:求第二大的最长升序子序列

分析:这里的第二大指的是,全部的递增子序列的长度(包含相等的),

从大到小排序后。排在第二的长度

cid=546" style="color:rgb(106,57,6); text-decoration:none">BestCoder Round #16 上的第二题,注意
 1 1 2 这组数据,答案应为2

思路1.每次将最长的两个上升子序列长度记录。最后再排序,取第二大的就可以

思路2.假设最长的上升子序列长度(ans)唯一,那第二大应为ans-1

否则,第二大的就为 ans

  1. #include<stdio.h>
  2. #include<algorithm>
  3. using namespace std;
  4. int a[1010],dp[1010][2],ans[2010],n;
  5. int main()
  6. {
  7. int T,i,j,k,x,y;
  8. scanf("%d",&T);
  9. while(T--){
  10. scanf("%d",&n);
  11. for(i=0;i<n;i++)
  12. scanf("%d",&a[i]);
  13. k=0;
  14. for(i=0;i<n;i++){
  15. dp[i][0]=1;
  16. dp[i][1]=0;
  17. for(j=0;j<i;j++){
  18. if(a[j]<a[i]){
  19. x=dp[j][0]+1;
  20. y=dp[j][1]+1;
  21. if(x>dp[i][0])   //更新最大的两个长度
  22. swap(x,dp[i][0]);
  23. if(x>y)
  24. swap(x,y);
  25. if(y>dp[i][1])
  26. dp[i][1]=y;
  27. }
  28. }
  29. ans[k++]=dp[i][0];  //将每次最大的两个值记录下来
  30. ans[k++]=dp[i][1];
  31. }
  32. sort(ans,ans+k);
  33. printf("%d\n",ans[k-2]); //输出排序后第二大的
  34. }
  35. return 0;
  36. }
  1. #include<stdio.h>
  2. #include<string.h>
  3. #define max(a,b) a>b?

    a:b

  4. int a[1010],dp[1010],num[1010],n;
  5. int main()
  6. {
  7. int T,i,j,cnt,ans;
  8. scanf("%d",&T);
  9. while(T--){
  10. scanf("%d",&n);
  11. for(i=0;i<n;i++)
  12. scanf("%d",&a[i]);
  13. ans=1;
  14. for(i=0;i<n;i++){
  15. num[i]=dp[i]=1;
  16. for(j=0;j<i;j++){
  17. if(a[j]<a[i]&&dp[j]+1>dp[i]){
  18. dp[i]=dp[j]+1;
  19. num[i]=num[j];   //记录出现的次数
  20. }
  21. else if(a[j]<a[i]&&dp[j]+1==dp[i])
  22. num[i]+=num[j];   //记录出现的次数
  23. }
  24. ans=max(ans,dp[i]); //记录最大值
  25. }
  26. cnt=0;
  27. for(i=0;i<n;i++)
  28. if(dp[i]==ans)
  29. cnt+=num[i];  //计算最大值出现的总次数
  30. if(cnt==1)          //这里改成cnt>1输出ans,否则ans-1,wrong了,非常郁闷
  31. printf("%d\n",ans-1);
  32. else
  33. printf("%d\n",ans);
  34. }
  35. return 0;
  36. }

hdu 5087 Revenge of LIS II ( LIS ,第二长子序列)的更多相关文章

  1. hdoj 5087 Revenge of LIS II 【第二长单调递增子】

    称号:hdoj 5087 Revenge of LIS II 题意:非常easy,给你一个序列,让你求第二长单调递增子序列. 分析:事实上非常easy.不知道比赛的时候为什么那么多了判掉了. 我们用O ...

  2. hdu 5087 Revenge of LIS II

    http://acm.hdu.edu.cn/showproblem.php?pid=5087 题意求第二长的上升序列. 在求最长上升序列的同时加上一个数组,来记录以i为结尾的有多少条序列.如果n+1为 ...

  3. hdu 5087 Revenge of LIS II (DP)

    题意: N个数,求第二长上升子序列的长度. 数据范围: 1. 1 <= T <= 1002. 2 <= N <= 10003. 1 <= Ai <= 1 000 0 ...

  4. HDU 5087 (线性DP+次大LIS)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5087 题目大意:求次大LIS的长度.注意两个长度相同的LIS大小比较,下标和大的LIS较大. 解题思 ...

  5. HDU5087 Revenge of LIS II (LIS变形)

    题目链接:pid=5087">http://acm.hdu.edu.cn/showproblem.php?pid=5087 题意: 求第二长的最长递增序列的长度 分析: 用step[i ...

  6. hdu5087 Revenge of LIS II (dp)

    只要理解了LIS,这道题稍微搞一下就行了. 求LIS(最长上升子序列)有两种方法: 1.O(n^2)的算法:设dp[i]为以a[i]结尾的最长上升子序列的长度.dp[i]最少也得是1,就初始化为1,则 ...

  7. BestCoder16 1002.Revenge of LIS II(hdu 5087) 解题报告

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5087 题目意思:找出第二个最长递增子序列,输出长度.就是说,假如序列为 1 1 2,第二长递增子序列是 ...

  8. HDOJ 5087 Revenge of LIS II DP

    DP的时候记录下能否够从两个位置转移过来. ... Revenge of LIS II Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: ...

  9. HDU5087——Revenge of LIS II(BestCoder Round #16)

    Revenge of LIS II Problem DescriptionIn computer science, the longest increasing subsequence problem ...

随机推荐

  1. flex布局以及相关属性

    容器的属性: 父元素设置display:flex:子元素即可使用flex布局. flex-direction 决定项目排列方向: .box { flex-direction: row | row-re ...

  2. 20道必须掌握的C++面试题

    20道必须掌握的C++面试题 在面试C++方面的工作时,经常会遇到各种面试题,这对应聘人员的知识掌握能力要求较高.本文将为大家带来的就是20道必须掌握的C++面试题,不要错过哦! 问1:请用简单的语言 ...

  3. Perl monks 的 快速回复

    on Jun 20, 2019 at 11:39 UTC ( #11101620=perlquestion: print w/replies, xml ) Need Help?? jimyokl ha ...

  4. Maven实战读书笔记(七):Maven常用功能

    7.1.资源排除 <resources> <!-- 启动过滤,包含的文件会被过滤掉 --> <resource> <directory>src/main ...

  5. Liskon替换原则

    肯定有不少人跟我刚看到这项原则的时候一样,对这个原则的名字充满疑惑.其实原因就是这项原则最早是在1988年,由麻省理工学院的一位姓里的女士(Barbara Liskov)提出来的. 定义1:如果对每一 ...

  6. (1) LVS基本概念和三种模式

    网站架构中,负载均衡技术是实现网站架构伸缩性的主要手段之一. 所谓"伸缩性",是指可以不断向集群中添加新的服务器来提升性能.缓解不断增加的并发用户访问压力.通俗地讲,就是一头牛拉不 ...

  7. Linux I2C驱动

    Linux I2C 驱动结构 i2c体系结构由三部分组成 i2C core i2c core提供了i2c 总线驱动 和 设备驱动的注册,注销方法 i2C and SMBus protocol 实现 i ...

  8. Vmware改成bridge方式联网

    1.在使用桥接之前,先在真机的'更改适配器设置中'禁用vmnet1和vmnet8 2.在VMware中定义一个桥接器 3.设置这个Linux虚拟机使用前一个步骤定义的桥接器--进入桥接器选择界面 4. ...

  9. 间谍网络(tarjan缩点)

    洛谷传送门 看着这道题给人感觉就是tarjan求SCC,然而还得判断是否能控制全部间谍,这就得先从可以贿赂的点dfs一遍. 如果没有全部被标记了,就输出NO,再从没被标记的点里找最小的标号. 如果全被 ...

  10. ubuntu 18.04取消自动锁屏以及设置键盘快捷锁屏

    1:操作设置取消自动锁屏: setting-->power--->never 2:  设置自动锁屏快捷键: 快捷键设置一般在setting-->devices--->keybo ...