zoukankan      html  css  js  c++  java
  • 300. 最长递增子序列

    • dp 时间复杂度O(N^2)
        public int lengthOfLIS(int[] nums) {
            int[] length = new int[nums.length]; // length[i] 代表以nums[i]结尾的最长上升子序列的长度
            for (int i = 0; i < nums.length; i++) {
                length[i] = 1;
                for (int j = 0; j < i; j++) {
                    if(nums[i] > nums[j]) {
                        if (length[j] + 1 > length[i]) {
                            length[i] = length[j] + 1;
                        }
                    }
                }
            }
    
            int result = 0;
            for (int len : length) {
                result = Math.max(result, len);
            }
            return result;
        }
    
    • dp + 二分查找 时间复杂度O(N*lg(N))


        public int lengthOfLIS(int[] nums) {
            int[] smallestTails = new int[nums.length];
            int realSize = 0;
            for (int i = 0; i < nums.length; i++) {
                int index = Arrays.binarySearch(smallestTails, 0, realSize, nums[i]);
                if (index < 0) {
                    int insertIndex = -index - 1; // insertIndex的逻辑由Arrays.binarySearch方法返回值的形式决定。
                    smallestTails[insertIndex] = nums[i];
                    realSize = Math.max(realSize, insertIndex + 1); // realSize 代表 smallestTails 不为0的部分的长度。
                } else {
                    smallestTails[index] = nums[i];
                }
            }
            return realSize;
        }
    
  • 相关阅读:
    前端知识之BOM和DOM
    jQuery基础
    前端知识之JavaScript知识
    前端知识之css样式
    前端知识之html基础
    pymsql模块
    数据库、表、表内容增删改查
    数据库
    python正则表达式
    python列表生成式
  • 原文地址:https://www.cnblogs.com/lasclocker/p/11442749.html
Copyright © 2011-2022 走看看