最大上升子序列长度
2017-08-09 15:47
218 查看
给你一个数组,求出它最大上升子序列的长度
比如数组
4 2 3 1 1 1 5
求出最大上升子序列长度也就是3,是2 3 5
注意子串和子序列的区别,子串连续,子序列不一定
那么看上面这个数组,一般的方法时间复杂度是o(n^2)
我这儿使用lower_bound(),复杂度为o(n*logn)
这个原理是
先给dp数组所有元素赋值 INF=0x3f3f3f3f
然后开始比较,使用上面的数组例子
***dp 0 1 2 3 4 5 6
零, INF INF INF INF INF INF INF
一,4 INF……
二,2 INF……
三,2 3 INF……
四,1 3 INF……
五,……
六,……
七,1 3 5 INF……
虽然结果是1 3 5但是长度一样,这个算法问题在于可能序列元素不同,但是长度一定是最大的的那个
下面是代码:
比如数组
4 2 3 1 1 1 5
求出最大上升子序列长度也就是3,是2 3 5
注意子串和子序列的区别,子串连续,子序列不一定
那么看上面这个数组,一般的方法时间复杂度是o(n^2)
我这儿使用lower_bound(),复杂度为o(n*logn)
这个原理是
先给dp数组所有元素赋值 INF=0x3f3f3f3f
然后开始比较,使用上面的数组例子
***dp 0 1 2 3 4 5 6
零, INF INF INF INF INF INF INF
一,4 INF……
二,2 INF……
三,2 3 INF……
四,1 3 INF……
五,……
六,……
七,1 3 5 INF……
虽然结果是1 3 5但是长度一样,这个算法问题在于可能序列元素不同,但是长度一定是最大的的那个
下面是代码:
#include<cstdio> #include<cstring> #include<cstdlib> #include<cmath> #include<algorithm> #include<iostream> using namespace std; int INF=0x3f3f3f3f; int main() { int dp[1005],a[1005],i,n; while(scanf("%d",&n)!=EOF) { for(i=0;i<n;i++) { scanf("%d",&a[i]); dp[i]=INF;//先给dp数组初始化INF } for(i=0;i<n;i++) { *lower_bound(dp,dp+n,a[i])=a[i]; //该函数是搜索dp数组内,第一个大于等于 a【i】的元素地址 } printf("%d\n",lower_bound(dp,dp+n,INF)-dp);//第一个为INF的地址减去首地址就是长度 } return 0; }
相关文章推荐
- HDU 5748 Bellovin(求最大上升子序列的长度)
- 最大上升子序列长度
- HDOJ --1950 Bridging signal【利用二分法来求最大上升子序列长度】
- tyvj 1208 最长不下降子序列2 求序列b1,b2,b3,…,bm中所有长度(n)最大上升子序列的个数
- hdoj 1950 Bridging signals【二分求最大上升子序列长度】【LIS】
- hdoj 1069 Monkey and Banana(上升子序列最大和)
- 用O(nlogn)的算法实现最大上升子序列(LIS)输出.
- 动态规划之最大公共序列+最长上升子序列
- hdu 5087 次长上升自序列的长度dp
- “最长上升子序列,最大连续子序列和,最长公共子串”的Java实现
- 最大连续递增/递减/非递增/非递减子序列的长度(二分优化)
- 总结---最大上升子序列(O(n²)解法)
- 求最长上升子序列的长度
- hdu5489(删除一段后的最长上升子序列长度)LIS
- Lintcode 114.最大上升连续子序列
- 求两个字符串公共子序列的最大长度(参考阿里巴巴2015研发笔试)(简单)
- 求最大公共子序列的长度
- poj 3903 Stock Exchange(求最长上升子序列长度)
- HDU 5569 长度为n的上升子序列个数d (大数模板+DP)
- 最长上升子序列(LIS)长度 O(nlogn)算法 hdu1950为例