Number of Longest Increasing Subsequence(dp)
Given an unsorted array of integers, find the number of longest increasing subsequence.
Example 1:
Input:
[1,3,5,4,7]
Output:
2
Explanation:
The two longest increasing subsequence are [1, 3, 4, 7] and [1, 3, 5, 7].Example 2:
Input:
[2,2,2,2,2]
Output:
5
Explanation:
The length of longest continuous increasing subsequence is 1, and there are 5 subsequences' length is 1, so output 5.Note:Length of the given array will be not exceed 2000 and the answer is guaranteed to be fit in 32-bit signed int.
分析
2个dp, 一个length的dp, 一个count的dp
cnt[i]以i为底长度为x的所有cnt都相加if len[i] = len[j] + 1: cnt[i] += cnt[j]除非将来有长度更长的len覆盖,否则cnt[i]得到所有该长度的cnt
Last updated
Was this helpful?