代码随想录 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 。

示例 2:

输入:nums = 0,1,0,3,2,3

输出:4

示例 3:

输入:nums = 7,7,7,7,7,7,7

输出:1

解题思路

本题是求子序列,则组成子系列的元素可能是不连续的,因此判断第i个元素的子序列的最大长度,需要编译i以前的所有元素。用dpi表示截止第i天的最长子序列的长度。需要用两层for循环遍历,外环遍历nums的每个元素,内环遍历从0到当前元素i的元素,根据题意可知,如果numsi大于numsj,则说明加上当前元素能组成严格递增子序列,dpi在自身和dpj+1取大。最后的结果是取dpi的最大值。

代码实现

cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        if (nums.size() == 0)  return 0;
        if (nums.size() == 1)  return 1;
        vector<int> dp(nums.size(), 1);
        dp[0] = 1;
        int result = 0;
        for (int i=1;i<nums.size();i++) {
            for (int j=0;j<i;j++) {
                if (nums[i]>nums[j]) {
                    dp[i] = max(dp[i], dp[j]+1);
                }
                result = max(result, dp[i]);
            }
        }
        return result;
    }
};
相关推荐
Shadow(⊙o⊙)1 天前
专题四:前缀和
数据结构·算法
JAVA面经实录9171 天前
高频算法面试题
java·计算机网络·算法·面试
qq_452396231 天前
第十一篇:《资源管理:Requests/Limits、ResourceQuota、LimitRange》
算法·贪心算法
Tisfy1 天前
LeetCode 2095.删除链表的中间节点:两次遍历 / 一次遍历(快慢指针)
算法·leetcode·链表·题解·双指针
Irissgwe1 天前
AVL树详解
数据结构·c++·算法·二叉树·c·二叉搜索树·avl
凌波粒1 天前
LeetCode--131.分割回文串(回溯算法)
算法·leetcode·职场和发展
workflower1 天前
互联网与大数据环境下制造服务模式
人工智能·自然语言处理·数据挖掘·自动驾驶·动态规划·制造
北域码匠1 天前
奇偶归并排序:并行计算的排序利器
数据结构·算法·c#·排序算法
成都易yisdong1 天前
上海某平面坐标系与CGCS2000坐标互转详解(含全域拟合点、实战案例、保密规范)
大数据·人工智能·算法
2601_961845151 天前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划