码迷,mamicode.com
首页 > 其他好文 > 详细

O(n log n)求最长上升子序列与最长不下降子序列

时间:2017-08-12 11:05:57      阅读:283      评论:0      收藏:0      [点我收藏+]

标签:close   ++   play   第一个   int   gif   color   二分   for   

考虑dp(i)表示新上升子序列第i位数值的最小值.由于dp数组是单调的,所以对于每一个数,我们可以二分出它在dp数组中的位置,然后更新就可以了,最终的答案就是dp数组中第一个出现正无穷的位置。

代码非常简单:

技术分享
 for(int i=0;i<n;i++)dp[i]=oo;
 for(int i=0;i<n;i++)*lower_bound(dp,dp+n,A[i])=A[i];
 printf("%d\n",(lower_bound(dp,dp+n,oo)-dp)); 
View Code

如果是最长不下降子序列的话只需要把第二行的lower_bound改成upper_bound就可以了。

如果是最长下降子序列或者最长不上升子序列的话只需要把原序列倒过来做一遍就好了。

O(n log n)求最长上升子序列与最长不下降子序列

标签:close   ++   play   第一个   int   gif   color   二分   for   

原文地址:http://www.cnblogs.com/FYH-SSGSS/p/7349230.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!