【算法四十六】300. 最长递增子序列

300. 最长递增子序列

动态规划:

java 复制代码
class Solution {
    public int lengthOfLIS(int[] nums) {
        //子问题以nums[i]结尾的最长子序列长度
        //如果nums[j]<nums[i],所以nums[i]可以接在nums[j]后面
        //状态方程:dp[i] = Math.max(dp[i],dp[j]+1)
        //从左到右

        int n = nums.length;
        int[] dp = new int[n];
        Arrays.fill(dp,1);
        int ans = 1;

        for(int i = 0;i<n;i++){
            for(int j = 0;j<i;j++){
                if(nums[j]<nums[i]){
                    dp[i] = Math.max(dp[i],dp[j]+1);
                }
            }
            //比较得答案
            ans = Math.max(ans,dp[i]);
        }

        return ans;
    }
}

时间复杂度:O(N²)

空间复杂度:O(N)

相关推荐
Frostnova丶13 小时前
【算法笔记】数学知识
笔记·算法
吴可可12313 小时前
AutoCAD 2016与2014二次开发关键差异
算法
雨白14 小时前
哈希:以时间换空间的算法实战
算法
San813_LDD16 小时前
[数据结构]LeetCode学习
数据结构·算法·图论
x1387028595716 小时前
c语言排雷游戏(基础版9*9)
c语言·算法·游戏
sheeta199817 小时前
LeetCode 每日一题笔记 日期:2026.06.06 题目:2196. 根据描述创建二叉树
笔记·算法·leetcode
小欣加油17 小时前
leetcode994 腐烂的橘子
数据结构·c++·算法·leetcode·bfs
QuZero18 小时前
Guava Cache Deep Dive
java·后端·算法·guava
随意起个昵称18 小时前
线性dp-LIS题目4(A Twisty Movement)
算法·动态规划