leetcode300. 最长递增子序列

java 复制代码
class Solution {
    public int lengthOfLIS(int[] nums) {
        //除了使用动态规划之外,还可以选择使用排序的方法。
        int[] maxLen = new int[nums.length];
        maxLen[0] = 1;
        for(int i = 1;i < nums.length;i++){
            int j = i-1;
            int maxPre = 0;
            for(;j >= 0;j--)
                if(nums[j] < nums[i])
                    maxPre = Math.max(maxPre,maxLen[j]);
            maxLen[i] = (maxPre > 0) ? maxPre+1 : 1;
        }
        int maxx = 0;
        for(int i = 0;i < nums.length;i++)
            maxx = Math.max(maxx,maxLen[i]);
        return maxx;
    }
}
相关推荐
JavaArchJourney19 分钟前
HashMap 源码分析
java
hrrrrb1 小时前
【Java Web 快速入门】十、AOP
java·前端·spring boot
xnglan1 小时前
蓝桥杯手算题和杂题简易做法
数据结构·数据库·c++·python·算法·职场和发展·蓝桥杯
凛冬君主1 小时前
插入排序专栏
java·算法·排序算法
檀越剑指大厂1 小时前
【开发语言】Groovy语言:Java生态中的动态力量
java·开发语言
stbomei1 小时前
C 语言判断一个数是否是素数的三种方法文章提纲
c语言·开发语言·算法
小牛壮士1 小时前
Tokenizer(切词器)的不同实现算法
开发语言·算法·c#
汤永红1 小时前
week1-[顺序结构]大海
c++·算法·信睡奥赛
Tina学编程2 小时前
线程P5 | 单例模式[线程安全版]~懒汉 + 饿汉
java·单例模式·线程安全
我们从未走散2 小时前
设计模式学习笔记-----单例模式
java·笔记·学习·单例模式·设计模式