Leetcode 673. Number of Longest Increasing Subsequence

Problem

Given an integer array nums, return the number of longest increasing subsequences.

Notice that the sequence has to be strictly increasing.

Algorithm

Dynamic Programming (DP). Use to lists dp_L[i] and dp_N[i] to save the length and size of longest increasing subsequences of the first i items. Then sum all the items with the longest length.

Code

python3 复制代码
class Solution:
    def findNumberOfLIS(self, nums: List[int]) -> int:
        nlen = len(nums)
        dp_L = [1] * nlen
        dp_N = [1] * nlen
        for i in range(1, nlen):
            dp_L[i] = 1
            dp_N[i] = 1
            for j in range(i):
                if nums[j] < nums[i]:
                    if dp_L[i] == dp_L[j] + 1:
                        dp_N[i] += dp_N[j]
                    if dp_L[i] <= dp_L[j]:
                        dp_L[i] = dp_L[j] + 1
                        dp_N[i] =  dp_N[j]
        
        ans = 0
        max_l = max(dp_L)
        for i in range(nlen):
            if max_l == dp_L[i]:
                ans += dp_N[i]
        return ans
相关推荐
2501_941623326 小时前
智慧农业监控平台中的多语言语法引擎与实时决策实践
leetcode
轻抚酸~7 小时前
KNN(K近邻算法)-python实现
python·算法·近邻算法
测试界的海飞丝8 小时前
10道软件测试面试题及其答案:
服务器·测试工具·职场和发展
Yue丶越9 小时前
【C语言】字符函数和字符串函数
c语言·开发语言·算法
小白程序员成长日记10 小时前
2025.11.24 力扣每日一题
算法·leetcode·职场和发展
有一个好名字10 小时前
LeetCode跳跃游戏:思路与题解全解析
算法·leetcode·游戏
AndrewHZ10 小时前
【图像处理基石】如何在图像中提取出基本形状,比如圆形,椭圆,方形等等?
图像处理·python·算法·计算机视觉·cv·形状提取
蓝牙先生11 小时前
简易TCP C/S通信
c语言·tcp/ip·算法
2501_9418705611 小时前
Python在高并发微服务数据同步与分布式事务处理中的实践与优化
leetcode
2501_9411477113 小时前
高并发微服务架构Spring Cloud与Dubbo在互联网优化实践经验分享
leetcode