首页 > 其他分享 >最长连续递增序列解题思路

最长连续递增序列解题思路

时间:2022-10-30 18:04:48浏览次数:57  
标签:nums int 递增 解题 序列 UE4 dp


题目

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

连续递增的子序列 可以由两个下标 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

解题思路

根据题意,本题可用动态规划的方式来求解。

第一步,确定dp数组以及下标的含义:

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

第二步,确定递推公式:

如果 nums[i + 1] > nums[i],那么以 i+1 为结尾的数组的连续递增的子序列长度一定等于 以 i 为结尾的数组的连续递增的子序列长度 + 1 。所以可以得出递推公式为:dp[i + 1] = dp[i] + 1;

第三步,dp 数组初始化:

连续递增的子序列长度最少是 1, 所以 dp 数组应该初始化为 1。

第四步,确定遍历顺序:

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

代码实现

class Solution {
public int findLengthOfLCIS(int[] nums) {
if(nums.length == 0){
return 0;
};
int count = 1;
int len = nums.length;
int[] dp = new int[len];
for(int i = 0; i < len; i++){
dp[i] = 1;
}

for(int i = 0; i < len - 1; i++){
if(nums[i+1] > nums[i]){
dp[i+1] = dp[i] + 1;
}
if(dp[i+1] > count) count = dp[i+1];
}

return count;
}
}

最后

  • 时间复杂度:O(n),其中 n 是数组 nums 的长度。
  • 空间复杂度:O(1)。

我是杰少,如果您觉的我写的不错,那请给我 点赞+评论+收藏 后再走哦!

往期文章:

  • ​​# UE4:来为我们的角色制作一个血条吧​​
  • ​​使用 Google Breakpad 来助力解决程序崩溃​​
  • ​​UE4 多人游戏服务器探索​​
  • ​​使用虚幻引擎自动化工具实现自动化部署​​
  • ​​如何在 UE4 中制作一扇自动开启的大门​​
  • ​​如何在 UE4 中用代码去控制角色移动​​
  • ​​如何给 UE4 场景添加游戏角色​​
  • ​​UE4:Android 平台开发实践指南​​
  • ​​UE4 开发避坑指南(持续更新)​​
  • ​​新年开工啦,放个小烟花庆祝一下​​
  • ​​聊聊与苹果审核员的爱恨情仇(下)​​
  • ​​聊聊与苹果审核员的爱恨情仇(上)​​
  • ​​一名普通工具人的 2021 | 2021年终总结​​
  • ​​二叉树刷题总结:二叉搜索树的属性​​
  • ​​二叉树总结:二叉树的属性​​
  • ​​二叉树总结:二叉树的修改与构造​​
  • ​​StoreKit2 有这么香?嗯,我试过了,真香​​
  • ​​看完这篇文章,再也不怕面试官问我如何构造二叉树啦!​​
  • ​​那帮做游戏的又想让大家氪金,太坏了!​​
  • ​​手把手带你撸一个网易云音乐首页 | 适配篇​​
  • ​​手把手带你撸一个网易云音乐首页(三)​​
  • ​​手把手带你撸一个网易云音乐首页(二)​​
  • ​​手把手带你撸一个网易云音乐首页(一)​​
  • ​​代码要写注释吗?写你就输了​​
  • ​​Codable发布这么久我就不学,摸鱼爽歪歪,哎~就是玩儿​​
  • ​​iOS 优雅的处理网络数据,你真的会吗?不如看看这篇​​
  • ​​UICollectionView 自定义布局!看这篇就够了​​
  1. 关注公众号--- HelloWorld杰少

标签:nums,int,递增,解题,序列,UE4,dp
From: https://blog.51cto.com/u_15452588/5807576

相关文章

  • 392.is-subsequence 判断子序列
    问题描述392.判断子序列解题思路与1143.最长公共子序列基本一样,只需要再判断结果是否和s.size()相等就好了。代码classSolution{public:boolisSubsequence......
  • 115.distinct-subsequence 不同的子序列
    问题描述115.不同的子序列解题思路dp[i][j]表示考虑考虑t的前j个字符在s的前i个字符中的出现个数:if(s[i-1]==t[j-1])dp[i][j]=dp[i-1][j-1]+dp[i-......
  • 300.longest-increasing-subsequence 最长递增子序列
    问题描述300.最长递增子序列解题思路关键在于,dp[i]表示什么含义便于解这道题,子序列不一定连续,所以为了便于求解,dp[i]应该表示为以nums[i-1]结尾的最长严格递增子序列......
  • 674.longest-continuous-increasing-subsequence 最长连续递增序列
    问题描述674.最长连续递增序列解题思路dp[i]表示以nums[i-1]结尾的最长连续递增子序列长度;递推关系为:if(nums[i-1]>nums[i-2])dp[i]=dp[i-1]+1......
  • pikachu php反序列化漏洞
    原理php中serialize(),unserialize()这两个函数。序列化serialize()序列化说通俗点就是把一个对象变成可以传输的字符串,比如下面是一个对象:classS{publ......
  • 15.几种序列化方式
    什么是序列化关于序列化相信大家都很了解,在Java中我们经常就可以看到很多实体类或者 POJO 都会实现 Serializable 接口,有了解过 Serializable 接口的小伙伴应该都......
  • 【WC2019】数树(prufer序列,树上连通块DP,多项式exp)
    设两棵树的边集分别为\(E_1,E_2\),那么两棵树不同当且仅当它们对应的边集不同。转化一下可以发现,染色方案等于\(y^{n-|E_1\capE_2|}\),即由边集\(E_1\capE_2\)构成的......
  • FastJson序列化和反序列化问题记录
    序列化与反序列化问题调用外部接口,http://100.111.55.67:9999/cmdb/v0.2.0/departments?page_size=1000,返回数据格式如下:{"code":0,"content":[{......
  • 能够作用于序列的一些运算符和函数
    1、序列:可以分为可变序列和不可变序列;(可变:列表;不可变:元组,字符串)2、“+、*”“+”:序列的加法表示两个序列的拼接   “*”:表示序列的重复,复制   3、列表,元组......
  • 动态规划树状数组优化(M元上升子序列)
    我们先来看简单版:P1637三元上升子序列这道题显然考虑dp,转移式子也很好写设f[i][j]表示以a[j]结尾长度为i的上升子序列个数。显然答案就是\(\sum\limits_{k=1}^{n}f_{3......