hard
arrays
dynamic-programming
binary-search
Given an integer array nums, return the length of the longest strictly increasing subsequence.
A subsequence is a sequence that can be derived from the array by deleting some or no elements without changing the order of the remaining elements.
Follow up
Can you come up with an algorithm that runs in O(n log n) time?
Examples
Example 1
Input: nums = [10,9,2,5,3,7,101,18]
Output: 4
Example 2
Input: nums = [0,1,0,3,2,3]
Output: 4
Example 3
Input: nums = [7,7,7,7,7,7,7]
Output: 1
Running will execute all 3 cases.