用O(nlog(n)实现最长递增子序列问题
来源:互联网 发布:linux centos安装教程 编辑:程序博客网 时间:2024/04/29 19:14
问题描述
输入一串数字,或数组,如-5, 1, -3, -1, -2, 1, 4, 8, 9, 7,则该数组的最长递增子序列之一(注意,最长递增子序列有时候不止一个)为-5,-3, -1, 1, 4, 8, 9
解决方案:
有两种思路:1. 用动态规划来解决(O(n^2)));2,用类似二分排序的方法来解决(O(nlog(n)))
思路一:
可以参考之前的博文最长递增子序列的求解--动态规划求解
思路二:
具体思路参考http://www.felix021.com/blog/read.php?entryid=1587&page=2&part=1,但他的代码有点问题,自己改了下
int dp_nlogn(int *data, int *auxData, int len){int seqLen = 1;int i, mid = 0, left = 1, right = 0;auxData[1] = data[1];for(i=2; i<=len; i++){left = 1; right = seqLen;while(left<=right)//find a pos to insert{mid = (left + right)/2;if(auxData[mid]<data[i])left = mid + 1;elseright = mid - 1;}if(left >= seqLen) //curLen is logger than beforeauxData[left] = data[i]; //insertif(left>seqLen) {seqLen++;}}return seqLen;}
- 用O(nlog(n)实现最长递增子序列问题
- 最长递增子序列问题,O(N*logN)实现
- 最长递增子序列(LIS) nlog(n)算法
- 最长递增子序列的nlog(n)算法
- ACM最长单调递增子序列问题(动态规划)o(n*n)C++实现
- ACM最长单调递增子序列问题(动态规划)o(n*n)C++实现
- hdu 6197 最长上升子序列 o(nlog(n))版
- 最长子序列问题(时间复杂度O(nlog(n))
- 最长递增子序列 O(n^2) 与 O(nlogn)
- 最长上升子序列 nlog(n)
- 最长上升子序列nlog(n)
- 【最长上升子序列nlog(n)】
- 最长递增子序列O(n^2)版
- 最长单调递增子序列(O(n^2))
- 动态规划解最长递增子序列(O(n^2))
- 51nod_1134 最长递增子序列(O(n*logn))
- O(nlog(n))的最长上升(不下降)子序列算法
- rqnoj-156-吞噬比赛-最长上升子序列O(nlog(n))算法
- 在C++中子类继承和调用父类的构造函数方法
- cent os 6.2 安装 zend guard
- FTP分页读取文件
- cocos2dx 添加移动基地计费代码后如何安全执行退出
- ibatis中使用truncate 问题
- 用O(nlog(n)实现最长递增子序列问题
- 关于学习C++和编程的50个观点
- 国外优秀 android 开发网站荟萃
- s6410解码问题---linux
- MySQL INSERT INTO语句
- STL系列之五heap
- c++操作符重载
- STL copy详解
- amcharts去除版权标志