day105(3.6)——leetcode面试经典150

300. 最长递增子序列

300. 最长递增子序列

今天坐了一天车,终于到学校了,太不容易了,然后一直坐车也没来得及吃饭,回来了就大吃特吃,结果吃撑了,十一点多才忙完,加油!!!明天收拾完东西就出发学习!!!

题目:

题解:

java 复制代码
class Solution {
    public int lengthOfLIS(int[] nums) {
        int n = nums.length;
        //dp数组表示到第k位是最多能有几个递增序列数
        int[] dp = new int[n];
        //最大序列可能不是以最后一个数结尾
        int maxx = 0;
        for(int i=0;i<n;i++) {
            dp[i]=Math.max(1, dp[i]);
            for(int j=0;j<i;j++) {
                if(nums[i]>nums[j]) {
                    dp[i]=Math.max(dp[j]+1, dp[i]);
                }
            }
            maxx = Math.max(maxx, dp[i]);
        }
        return maxx;
    }
}

虽然这不是最优解,最优解是动态规划+二分:

java 复制代码
// Dynamic programming + Dichotomy.
class Solution {
    public int lengthOfLIS(int[] nums) {
        int[] tails = new int[nums.length];
        int res = 0;
        for(int num : nums) {
            int i = 0, j = res;
            while(i < j) {
                int m = (i + j) / 2;
                if(tails[m] < num) i = m + 1;
                else j = m;
            }
            tails[i] = num;
            if(res == j) res++;
        }
        return res;
    }
}
相关推荐
wljy13 分钟前
每日一题(2026.4.29) 猫猫与数学
c语言·c++·算法·蓝桥杯·stl·牛客
sali-tec6 分钟前
C# 基于OpenCv的视觉工作流-章56-OCR
图像处理·人工智能·opencv·算法·计算机视觉·ocr
M ? A6 分钟前
Vue 转 React | VuReact编译工具快速入门
前端·javascript·vue.js·后端·react.js·面试·vureact
MicroTech202510 分钟前
微算法科技(NASDAQ:MLGO)混合经典量子算法:赋能数字图像处理的创新路径
科技·算法·量子计算
yu859395811 分钟前
降低OFDM系统PAPR的各种算法及误码率分析
前端·算法
2501_9130613412 分钟前
JVM虚拟机——面试中的八股文(下)
java·jvm·面试
阿Y加油吧15 分钟前
二刷 LeetCode:5. 最长回文子串 & 1143. 最长公共子序列 复盘笔记
笔记·算法·leetcode
xiaoxue..22 分钟前
浅聊ReAct:Agent 的执行框架
ai·面试·agent
广州灵眸科技有限公司32 分钟前
瑞芯微(EASY EAI)RV1126B AI算法开发流程
人工智能·算法·机器学习
Rabitebla1 小时前
【C++】string 类:原理、踩坑与对象语义
linux·c语言·数据结构·c++·算法·github·学习方法