000673-Number-of-Longest-Increasing-Subsequence
Problem
Solution
class Solution:
def findNumberOfLIS(self, nums: List[int]) -> int:
if not nums or len(nums) == 0:
return 0
n, max_len, res = len(nums), 1, 0
dp = [1] * n
cnt = [1] * n
for r in range(n):
for l in range(r):
# when right > left, found increase sequence, +1
if nums[r] > nums[l]:
if dp[l]+1 == dp[r]:
cnt[r] += cnt[l]
# only when left sequence + 1 > right sequence, right sequence +1
elif dp[l]+1 > dp[r]:
dp[r] = dp[l] + 1
cnt[r] = cnt[l]
if max_len == dp[r]:
res += cnt[r]
if max_len < dp[r]:
max_len = dp[r]
res = cnt[r]
return res
#
# [1,3,5,4,7]
# dp = [1, 2, 3, 3, 4]
# cnt = [1, 1, 1, 1, 2]Last updated