最长上升子序列的O(nlgn)解法

原创 2013年12月03日 19:17:23

感觉网上说的太复杂了……

今天我突然想明白了,写起来不过三行代码而已。

 

首先换一种状态表示:设f[i]为长度为i的上升子序列中末尾元素的最小值,
初始化f[0]=INT_MIN,f[1~N]=INT_MAX
然后对于每个元素,更新集合 { f[i] | f[i-1]<a[j] } 中的所有f[i]的最小值,
以上方法O(n^2)


由于f[i-1]<a[j](上面集合中的条件),
所以用于更新的a[j]一定比更新上一位置的那玩意大,所以f数组单调递增,
前面比a[j]小的更新不走,只有更新中间那个位置的,
或者说对于一个a[j],只可能更新一个,就是上一个还小的,下一个就比它大的那个,

用二分优化更新过程~~O(nlgn)

实现比O(n^2)的方法还简单!只需要三行代码!~~~~~~~~
fill(f,f+n,INT_MAX);
for(int i=0;i<n;++i)
    *lower_bound(f,f+n,a[i])=a[i];

版权声明:本文为本人原创,允许转载,但转载请注明出处:http://blog.csdn.net/kingpharaoh

相关文章推荐

【线段树+O(nlgn)最长上升子序列】HDU 3564

the k-th number Xk means that we add number k at position Xk (0 注意插数的时候是插到当前序列里,也就是说不可能插到当前序列末尾,还有,这...

LintCode -- 最长上升子序列 O(nlgn)

LintCode -- longest-increasing-subsequence(最长上升子序列) 原题链接:http://www.lintcode.com/zh-cn/problem/lon...

最长公共上升子序列(LCIS)问题的O(n^2)解法

J - 病毒 Time Limit:3000MS     Memory Limit:131072KB     64bit IO Format:%lld & %llu Subm...

每日三题-Day5-A(POJ 2533 Longest Ordered Subsequence 最长上升子序列O(nlogn)解法)

Longest Ordered Subsequence Time Limit: 2000MS   Memory Limit: 65536K Total Submissi...

POJ 1631 Bridging signals(最长上升子序列 nlgn做法)

传送门:http://poj.org/problem?id=1631 Bridging signals Time Limit: 1000MS   Memory Limit: 1...

求最长升序子序列O(nlgn)的算法---HDOJ 1025

求解最长升/降序子序列是动规的经典问题,朴素动规的时间复杂度为O(n^2), 状态的转移方程为dp[i]=max{dp[j]}+1,其中j 现在我们对上面的转移方程再做一个限定,当有多个j满足条件...

poj 1036 Gangster -- 最长上升子序列解法

/* * poj 1036 Gangster 题目大意: N个抢匪陆续的进入一家餐馆,餐馆的们有K个开放度,每个绑匪只有在开放度适合 自己时才能进入,并给...

POJ2533, 最长上升子序列(贪心+二分查找时间复杂度O(nlogn))

解题思路参考这位大神的博客:点击打开链接。 在这里,我介绍下我对该方法的理解。 使用这种方法是对动态规划方法的一种优化,在用动态规划求解时,求到第i个元素的最长上升子序列时,是在前i-1个数中寻找,比...

最长上升子序列(LIS)长度的O(nlogn)算法

hdu 1950 Bridging signals http://acm.hdu.edu.cn/showproblem.php?pid=1950 =========================...
  • czkct
  • czkct
  • 2015-11-20 23:08
  • 223

最长上升子序列O(n*lg(n))代码

问题描述: 所谓子序列,就是在原序列里删掉若干个元素后剩下的序列,以字符串"abcdefg"为例子,去掉bde得到子序列"acfg" 现在的问题是,给你一个数字序列,你要求出它最长的单调递增子序列...
  • leo115
  • leo115
  • 2012-06-05 09:39
  • 1620
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)