【LeetCode-674】最长连续递增序列(动归)

目录

LeetCode674.最长连续递增序列

题目描述

解法1:动态规划

代码实现


题目链接

题目描述

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

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

示例 1:

  • 输入:nums = [1,3,5,4,7]

  • 输出:3

  • 解释:最长连续递增序列是 [1,3,5], 长度为3。尽管 [1,3,5,7] 也是升序的子序列, 但它不是连续的,因为 5 和 7 在原数组里被 4 隔开。

示例 2:

  • 输入:nums = [2,2,2,2,2]

  • 输出:1

  • 解释:最长连续递增序列是 [2], 长度为1。

提示:

  • 0 <= nums.length <= 10^4

  • -10^9 <= nums[i] <= 10^9

解法1:动态规划

这个题求连续的递增序列,我们在遍历的过程中,也可以使用dp数组将我们每一个位置的最长递增序列表示出来,如果当前nums数组的值大于上一个位置的值,那么看上一个dp[i-1]的值,如果不为0则dp[i] = dp[i-1] + 1;

  1. 确定dp数组(dp table)以及下标的含义

dp[i]:以下标i为结尾的连续递增的子序列长度为dp[i]

注意这里的定义,一定是以下标i为结尾,并不是说一定以下标0为起始位置。

  1. 确定递推公式

如果 nums[i] > nums[i - 1],那么以 i 为结尾的连续递增的子序列长度 一定等于 以i - 1为结尾的连续递增的子序列长度 + 1 。

即:dp[i] = dp[i - 1] + 1;

因为本题要求连续递增子序列,所以就只要比较nums[i]与nums[i - 1],而不用去比较nums[j]与nums[i] (j是在0到i之间遍历)。

  1. dp数组如何初始化

以下标i为结尾的连续递增的子序列长度最少也应该是1,即就是nums[i]这一个元素。所以dp[i]应该初始1;

  1. 确定遍历顺序

从递推公式上可以看出, dp[i + 1]依赖dp[i],所以一定是从前向后遍历。

本文在确定递推公式的时候也说明了为什么本题只需要一层for循环,代码如下:

java 复制代码
for (int i = 1; i < nums.size(); i++) {
    if (nums[i] > nums[i - 1]) { // 连续记录
        dp[i] = dp[i - 1] + 1;
    }
}
代码实现
java 复制代码
class Solution {
    public int findLengthOfLCIS(int[] nums) {
        int len = nums.length;
        if (len == 1) return 1;
        int max = 0;
        int temp = 1;
        for (int i = 1; i < len; i++) {
            if (nums[i] > nums[i-1]) {
                temp++;
            }else {
                temp = 1;
            }
            max = Math.max(max,temp);
        }
​
        return max;
    }
}
相关推荐
艾醒3 分钟前
大模型面试题剖析:Pre-Norm与Post-Norm的对比及当代大模型选择Pre-Norm的原因
算法
怀旧,17 分钟前
【C++】 9. vector
java·c++·算法
渣哥36 分钟前
震惊!Java注解背后的实现原理,竟然如此简单又高深!
java
hqxstudying41 分钟前
JAVA限流方法
java·开发语言·安全·限流
shylyly_1 小时前
Linux->多线程2
java·linux·多线程·线程安全·线程同步·线程互斥·可重入
浩浩测试一下1 小时前
06高级语言逻辑结构到汇编语言之逻辑结构转换 for (...; ...; ...)
汇编·数据结构·算法·安全·web安全·网络安全·安全架构
小蒜学长2 小时前
基于实例教学的软件工程专业教学系统
java·spring boot·后端·软件工程
Code_Artist2 小时前
[Java并发编程]3.同步锁的原理
java·后端·面试
渣哥2 小时前
面试必问!JDK动态代理和CGLIB动态代理的核心区别
java