hdu 5087 Revenge of LIS II ( LIS ,第二长子序列)
题意:求第二大的最长升序子序列
分析:这里的第二大指的是,全部的递增子序列的长度(包含相等的),
从大到小排序后。排在第二的长度
cid=546" style="color:rgb(106,57,6); text-decoration:none">BestCoder Round #16
上的第二题,注意
1 1 2 这组数据,答案应为2
思路1.每次将最长的两个上升子序列长度记录。最后再排序,取第二大的就可以
思路2.假设最长的上升子序列长度(ans)唯一,那第二大应为ans-1
否则,第二大的就为 ans
- #include<stdio.h>
- #include<algorithm>
- using namespace std;
- int a[1010],dp[1010][2],ans[2010],n;
- int main()
- {
- int T,i,j,k,x,y;
- scanf("%d",&T);
- while(T--){
- scanf("%d",&n);
- for(i=0;i<n;i++)
- scanf("%d",&a[i]);
- k=0;
- for(i=0;i<n;i++){
- dp[i][0]=1;
- dp[i][1]=0;
- for(j=0;j<i;j++){
- if(a[j]<a[i]){
- x=dp[j][0]+1;
- y=dp[j][1]+1;
- if(x>dp[i][0]) //更新最大的两个长度
- swap(x,dp[i][0]);
- if(x>y)
- swap(x,y);
- if(y>dp[i][1])
- dp[i][1]=y;
- }
- }
- ans[k++]=dp[i][0]; //将每次最大的两个值记录下来
- ans[k++]=dp[i][1];
- }
- sort(ans,ans+k);
- printf("%d\n",ans[k-2]); //输出排序后第二大的
- }
- return 0;
- }
- #include<stdio.h>
- #include<string.h>
- #define max(a,b) a>b?
a:b
- int a[1010],dp[1010],num[1010],n;
- int main()
- {
- int T,i,j,cnt,ans;
- scanf("%d",&T);
- while(T--){
- scanf("%d",&n);
- for(i=0;i<n;i++)
- scanf("%d",&a[i]);
- ans=1;
- for(i=0;i<n;i++){
- num[i]=dp[i]=1;
- for(j=0;j<i;j++){
- if(a[j]<a[i]&&dp[j]+1>dp[i]){
- dp[i]=dp[j]+1;
- num[i]=num[j]; //记录出现的次数
- }
- else if(a[j]<a[i]&&dp[j]+1==dp[i])
- num[i]+=num[j]; //记录出现的次数
- }
- ans=max(ans,dp[i]); //记录最大值
- }
- cnt=0;
- for(i=0;i<n;i++)
- if(dp[i]==ans)
- cnt+=num[i]; //计算最大值出现的总次数
- if(cnt==1) //这里改成cnt>1输出ans,否则ans-1,wrong了,非常郁闷
- printf("%d\n",ans-1);
- else
- printf("%d\n",ans);
- }
- return 0;
- }
hdu 5087 Revenge of LIS II ( LIS ,第二长子序列)的更多相关文章
- hdoj 5087 Revenge of LIS II 【第二长单调递增子】
称号:hdoj 5087 Revenge of LIS II 题意:非常easy,给你一个序列,让你求第二长单调递增子序列. 分析:事实上非常easy.不知道比赛的时候为什么那么多了判掉了. 我们用O ...
- hdu 5087 Revenge of LIS II
http://acm.hdu.edu.cn/showproblem.php?pid=5087 题意求第二长的上升序列. 在求最长上升序列的同时加上一个数组,来记录以i为结尾的有多少条序列.如果n+1为 ...
- hdu 5087 Revenge of LIS II (DP)
题意: N个数,求第二长上升子序列的长度. 数据范围: 1. 1 <= T <= 1002. 2 <= N <= 10003. 1 <= Ai <= 1 000 0 ...
- HDU 5087 (线性DP+次大LIS)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5087 题目大意:求次大LIS的长度.注意两个长度相同的LIS大小比较,下标和大的LIS较大. 解题思 ...
- HDU5087 Revenge of LIS II (LIS变形)
题目链接:pid=5087">http://acm.hdu.edu.cn/showproblem.php?pid=5087 题意: 求第二长的最长递增序列的长度 分析: 用step[i ...
- hdu5087 Revenge of LIS II (dp)
只要理解了LIS,这道题稍微搞一下就行了. 求LIS(最长上升子序列)有两种方法: 1.O(n^2)的算法:设dp[i]为以a[i]结尾的最长上升子序列的长度.dp[i]最少也得是1,就初始化为1,则 ...
- BestCoder16 1002.Revenge of LIS II(hdu 5087) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5087 题目意思:找出第二个最长递增子序列,输出长度.就是说,假如序列为 1 1 2,第二长递增子序列是 ...
- HDOJ 5087 Revenge of LIS II DP
DP的时候记录下能否够从两个位置转移过来. ... Revenge of LIS II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: ...
- HDU5087——Revenge of LIS II(BestCoder Round #16)
Revenge of LIS II Problem DescriptionIn computer science, the longest increasing subsequence problem ...
随机推荐
- resnet.caffemodel
http://blog.csdn.net/baidu_24281959/article/details/53203757
- QT_3
1.QT中命名的规范和常用的快捷键 1.1 命名规范: 类名:首字母大写 多个单词时单词与单词之间首 字母大写 函数名:变量名称 首字母小写 多个单词时,单词和单词之间首字母大写 1. ...
- JavaEE-03 JSP数据交互02
学习要点 application pageContext JSP对象作用域 cookie application 作用 类似于系统的“全局变量”,用于在同一个服务器内的所有用于之间的数据共享,对于整个 ...
- 连接mysql 2003 Can't connect to Mysql on 'xxx'(10061)
备份 cp /etc/mysql/my.cnf /etc/mysql/my.cnf.bak 修改 vim /etc/mysql/my.cnf 在[mysqld]下修改为bind-address=0.0 ...
- 基于selenium爬取拉勾网职位信息
1.selenium Selenium 本是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.而这一特性为爬虫开发提供了一个选择及方向,由于其本身依赖 ...
- Hibernate入门(1)——环境搭建
什么是Hibernate?为什么使用Hibernate?Hibernate有什么优缺点?网上很多大神的文章又详细又通俗易懂. 步骤: 1.创建数据库表格. 2.编写JavaBean实体类. 3.下载H ...
- 【07】QQ群管理公告小结:
[07]QQ群管理公告小结: 01,请看公告遵守相关规定. 02,群内除QQ自带的缺省表情外(不是QQ的VIP或大图表情),禁止发送大表情,大图片(展示问题的屏幕截图除外), 03,修改群名片 ...
- xtu summer individual 1 A - An interesting mobile game
An interesting mobile game Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on H ...
- gitHub网站上常见英语翻译
为开发者而建Built for developers GitHub is a development platform inspired by the way you work.GitHub是一个受你 ...
- 在RedHat 5下安装Oracle 10g详解(转)
在RedHat 5下安装Oracle 10g详解(转) Posted on 2012-09-14 13:26 疯狂 阅读(5075) 评论(0) 编辑 收藏 所属分类: database .uni ...