【leetcode hot 100 300】最长递增子序列

错误解法:在每次更新db[i]时,如果当前nums[i]>nums[i-1]就db[i-1]+1,否则db[i-1]

java 复制代码
class Solution {
    public int lengthOfLIS(int[] nums) {
        int n = nums.length;
        int[] db = new int[n]; // db[i]表示到i的最长严格递增子序列的长度
        db[0] = 1;
        for (int i = 1; i < n; i++) {
            db[i] = nums[i-1]<nums[i]?db[i-1]+1:db[i-1];
        }
        return db[n-1];
    }
}

错误原因:4<10 被记为1;后面3<8<9会在这个1上进行累加,但是10>3 8 9的,不正确

解法一:(动态规划)①定义:dp[i]表示以下标为i的字母结尾的最长严格递增子序列,dp[n] ②初始状态:dp[0]=1 ③状态转移方程:dp[i] = nums[j]<nums[i]?Math.max(db[j]+1,db[i]):1; max=Math.max(max,dp[i])(dp[i] = nums[i-1]<nums[i]?dp[i-1]+1:1❌没有考虑非连续性)

java 复制代码
class Solution {
    public int lengthOfLIS(int[] nums) {
        // 定义:dp[i]表示以下标为i的字母结尾的最长严格递增子序列,dp[n]
        // 初始状态:dp[0]=1
        // 状态转移方程:dp[i] = nums[j]<nums[i]?Math.max(db[j]+1,db[i]):1; max=Math.max(max,dp[i])
        // dp[i] = nums[i-1]<nums[i]?dp[i-1]+1:1❌没有考虑非连续性
        int n = nums.length;
        int[] db = new int[n]; // db[i]表示以i解为的最长严格递增子序列的长度
        db[0] = 1;
        int max = 1;
        for (int i = 1; i < n; i++) {
            db[i]=1; // db[i]最少包含它本身,赋值为1
            for(int j = 0;j<i;j++){
                if(nums[i]>nums[j]){
                    // nums[j]>nums[i]严格递增,可以取以i结尾的最长长度+1
                    db[i] = Math.max(db[j]+1,db[i]);
                }
            }
            max = Math.max(max, db[i]);
        }
        // 返回的结果是最长递增子序列,而不是以i结尾的最长递增,不能返回db[n-1]
        // 返回结果要在过程中记录
        return max;
    }
}

注意:

  • db[i]表示以i为结尾的最长严格递增子序列的长度。
  • 返回的结果是最长递增子序列,而不是以i结尾的最长递增,不能返回db[n-1]。返回结果要在过程中记录。
  • dp[i]可以直接表示题目要求,也可以表示另外的含义,辅助算出题目要求,eg:db[i]表示以i为结尾的最长严格递增子序列的长度
相关推荐
CoovallyAIHub6 小时前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub7 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub7 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub7 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub8 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞8 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕9 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub10 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub10 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉