题意:
给一个数组,求严格递增的最长递增子序列的长度。
思路:
开销是一个额外的O(n)的数组。lower_bound(begin,end,val)的功能是:返回第一个大于等于val的地址。
data:image/s3,"s3://crabby-images/be328/be3281918b0b8a9eec8945671c0adda2e7e8e6c6" alt="LeetCode Longest Increasing Subsequence (LIS O(nlogn)) LeetCode Longest Increasing Subsequence (LIS O(nlogn))"
data:image/s3,"s3://crabby-images/2c7ff/2c7ff242273ebcca11565977752e209fbc764d2e" alt="LeetCode Longest Increasing Subsequence (LIS O(nlogn)) LeetCode Longest Increasing Subsequence (LIS O(nlogn))"
1 class Solution { 2 public: 3 int lengthOfLIS(vector<int>& nums) { 4 if(nums.empty()) return 0; 5 int *p=new int[nums.size()]; 6 p[0]=nums[0]; 7 int len=0; 8 for(int i=1; i<nums.size(); i++) 9 { 10 if(nums[i]>p[len]) 11 p[++len]=nums[i]; 12 else 13 *lower_bound(p,p+len+1,nums[i])=nums[i]; 14 } 15 delete []p; 16 return ++len; 17 } 18 };