题解 | #最长上升子序列(一)#

最长上升子序列(一)

https://www.nowcoder.com/practice/5164f38b67f846fb8699e9352695cd2f

class Solution:
    def LIS(self, arr: List[int]) -> int:
        n = len(arr)
        if n == 0:
            return 0

        dp = [1] * n  # 初始化dp数组,每个元素至少可以单独成为一个子序列

        for i in range(1, n):
            for j in range(i):
                if arr[i] > arr[j]:
                    dp[i] = max(dp[i], dp[j] + 1)  # 更新dp[i]为以arr[i]结尾的最长上升子序列长度

        return max(dp)  # 返回dp数组中的最大值,即最长上升子序列的长度

全部评论

相关推荐

给大家传递好运~
投递字节跳动等公司10个岗位
点赞 评论 收藏
分享
09-16 16:47
门头沟学院 C++
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
08-08 18:20
职场水母:这题思路是什么,我目前想的一个暴力方法就是先把这个链表遍历一遍,用哈希表存储出现次数,然后再根据哈希表来一个一个删除节点,
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务