Longest Increasing Subsequence
神特么可以O(nlgn)做,原理不是很容易讲,但是implementation很容易理解,照背就是
class Solution(object):
def lengthOfLIS(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
n = len(nums)
dp = []
for num in nums:
index = bisect.bisect_left(dp, num)
if index >= len(dp):
dp.append(num)
else:
dp[index] = num
return len(dp)
Java未优化版
class Solution {
public int lengthOfLIS(int[] nums) {
int n = nums.length;
int[] dp = new int[n];
int result = 0;
for (int i = 0; i < n; i++) {
dp[i] = 1;
for (int j = 0; j < i; j++) {
if (nums[j] < nums[i]) {
dp[i] = Math.max(dp[i], dp[j] + 1);
}
}
result = Math.max(result, dp[i]);
}
return result;
}
}