Longest Continuous Increasing Subsequence LT674
Posted taste-it-own-it-love-it
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Longest Continuous Increasing Subsequence LT674相关的知识,希望对你有一定的参考价值。
Given an unsorted array of integers, find the length of longest continuous
increasing subsequence (subarray).
Example 1:
Input: [1,3,5,4,7] Output: 3 Explanation: The longest continuous increasing subsequence is [1,3,5], its length is 3. Even though [1,3,5,7] is also an increasing subsequence, it‘s not a continuous one where 5 and 7 are separated by 4.
Example 2:
Input: [2,2,2,2,2] Output: 1 Explanation: The longest continuous increasing subsequence is [2], its length is 1.
Idea 1. Dynamic programming, Let len[i] repents the length of the continuous increasing subsequence which ends at nums[i],
len[i] = len[i-1] + 1 if nums[i-1] < nums[i]
len[i] = 1 otherwise
Time complexity: O(N)
Space complexity: O(1)
class Solution { public int findLengthOfLCIS(int[] nums) { int len = 0; int maxLen = 0; for(int i = 0; i < nums.length; ++i) { if(i > 0 && nums[i-1] < nums[i]) { len += 1; } else { len = 1; } maxLen = Math.max(maxLen, len); } return maxLen; } }
Idea 1.b mark the anchor to store the start of the continuous increasing subsequence,
class Solution { public int findLengthOfLCIS(int[] nums) { int anchor = 0; int maxLen = 0; for(int i = 0; i < nums.length; ++i) { if(i > 0 && nums[i-1] >= nums[i]) { anchor = i; } maxLen = Math.max(maxLen, i - anchor + 1); } return maxLen; } }
以上是关于Longest Continuous Increasing Subsequence LT674的主要内容,如果未能解决你的问题,请参考以下文章
674. Longest Continuous Increasing Subsequence
674. Longest Continuous Increasing Subsequence
674. Longest Continuous Increasing Subsequence
Longest Increasing Continuous Subsequence