首页 > 其他 > 详细

300. 最长递增子序列

时间:2019-09-01 19:00:09      阅读:68      评论:0      收藏:0      [点我收藏+]
  • 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;
    }

300. 最长递增子序列

原文:https://www.cnblogs.com/lasclocker/p/11442749.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!