力扣题解(最长连续递增序列)

674. 最长连续递增序列

给定一个未经排序的整数数组,找到最长且连续递增的子序列,并返回该序列的长度。

连续递增的子序列 可以由两个下标 lrl < r)确定,如果对于每个 l <= i < r,都有 nums[i] < nums[i + 1] ,那么子序列 [nums[l], nums[l + 1], ..., nums[r - 1], nums[r]] 就是连续递增子序列。

思路:

对于0到i位置,最长的连续递增子序列有可能是k到j的部分(k<j<i),或者m到i的位置(m<i),则可以利用双指针的思想,l表示当前递增子序列的开头,i表示结尾,当num[i]>num[i-1]的时候,则i++,表示i位置元素加入仍是递增子序列。当num[i]<=num[i-1]的时候,更新长度len,更新l=i,继续找下一个递增子序列。

复制代码
class Solution {
public:
    int findLengthOfLCIS(vector<int>& nums) {
       int l=0,len=0;
       int i=1;
       for(;i<nums.size();i++)
       {
        if(nums[i]>nums[i-1])
        {
             
        }
        else
        {
           len=max(len,i-l);
           l=i;
        }

       }
       len=max(len,i-l);
       return len;
    }
};
相关推荐
再难也得平3 分钟前
[LeetCode刷题]283.移动零(通俗易懂的java题解)
java·算法·leetcode
不想看见4045 分钟前
House Robber 基本动态规划:一维--力扣101算法题解笔记
笔记·算法·leetcode·代理模式
掘根6 分钟前
【C++STL】红黑树(RBTree)
数据结构·c++·算法
我笑了OvO6 分钟前
常见位运算及其经典算法题(1)
c++·算法·算法竞赛
Zevalin爱灰灰7 分钟前
方法论——如何设计控制策略架构
算法·架构·嵌入式
wostcdk9 分钟前
基础算法学习1
算法
Zik----9 分钟前
Leetcode20 —— 有效的括号(栈解法)
数据结构
Yzzz-F10 分钟前
2026牛客寒假算法基础集训营1
算法
野犬寒鸦12 分钟前
Java8 ConcurrentHashMap 深度解析(底层数据结构详解及方法执行流程)
java·开发语言·数据库·后端·学习·算法·哈希算法
m0_5312371719 分钟前
C语言-函数递归练习
算法