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;
    }
posted @ 2019-09-01 16:42  lasclocker  阅读(147)  评论(0编辑  收藏  举报