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;
    }
}
相关推荐
野生技术架构师4 小时前
一线大厂Java面试八股文全栈通关手册(含源码级详解)
java·开发语言·面试
小月球~4 小时前
天梯赛 · 并查集
数据结构·算法
仍然.5 小时前
算法题目---模拟
java·javascript·算法
6Hzlia6 小时前
【Hot 100 刷题计划】 LeetCode 118. 杨辉三角 | C++ 动态规划题解
c++·leetcode·动态规划
潇冉沐晴7 小时前
DP——背包DP
算法·背包dp
GIOTTO情7 小时前
2026 世界互联网大会亚太峰会|AI 时代媒介投放的技术实战与算法优化
人工智能·算法
逆境不可逃7 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾8 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
副露のmagic8 小时前
哈希章节 leetcode 思路&实现
算法·leetcode·哈希算法
副露のmagic8 小时前
字符串章节 leetcode 思路&实现
windows·python·leetcode