DAY52 300.最长递增子序列

编程入门 行业动态 更新时间:2024-10-27 12:26:39

DAY52 300.最长递增子<a href=https://www.elefans.com/category/jswz/34/1769864.html style=序列"/>

DAY52 300.最长递增子序列

300.最长递增子序列

题目要求:给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。

子序列是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。

示例 1:

  • 输入:nums = [10,9,2,5,3,7,101,18]
  • 输出:4
  • 解释:最长递增子序列是 [2,3,7,101],因此长度为 4 。

思路

dp[i]表示到"i"位置截至的最长递增子序列的长度,dp[i] = max(dp[i-1], count); 这里count还需要判断一下nums[i]和nums[i-1]的关系,来判断当前子序列是否是递增子序列。初始化dp[0] = 1;

但是这种方法只能处理连续的递增子序列,现在最长递增子序列可以是不连续的。

因此经过思考,我认为dp[i]应该存储两个值,一个是以nums[i]为结尾的最长递增子序列长度,另一个是不论是否以nums[i]为结尾的最长递增子序列长度;

  • 以nums[i]为结尾的:dp[i][0] = maxn + 1 // maxn代表i之前比nums[i]小的,且为结尾的最大长度
  • 因此maxn应该是max(num[j][0]);
  • 不论是否以nums[i]为结尾:dp[i][1] = max(dp[i][0], i之前的全局最大值);

返回max(dp[nums.size()-1][0], dp[nums.size()-1][1]);                                                                        bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbvv vvvvvvvvvvvvvvvvvv                                                                                                                                                                                                                                                         ZZZZZZZZZqwq!@Q        2

更多推荐

DAY52 300.最长递增子序列

本文发布于:2023-11-15 03:12:01,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1592708.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:序列   最长

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!