Problems

Longest Increasing Subsequence

hard
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.