码迷,mamicode.com
首页 > 其他好文 > 详细

最长升序列 DP

时间:2019-09-11 11:47:03      阅读:89      评论:0      收藏:0      [点我收藏+]

标签:on()   image   http   info   img   nbsp   com   结果   elf   

class Solution:
    def lengthOfLIS(self,nums):
        if not nums:return 0                    #边界处理
        dp = [1 for _ in range(len(nums))]      #转态的定义,dp[i]表示当前时刻的最长升序列的值
        for i in range(len(nums)):              #第一次从前向后遍历
            for j in range(i):                  #从0到当前时刻遍历
                if nums[j] < nums[i]:           #如果出现升序的情况
                    dp[i] = max(dp[i],dp[j]+1)  #状态转移为当前时刻与之前时刻+1的最大值作为当前的状态
        print(dp)
        return max(dp)
if __name__ == __main__:
    solution = Solution()
    nums = [10,9,2,5,3,7,101,18]                #结果是[2,3,7,101] 长度为4
    res = solution.lengthOfLIS(nums)
    print(最长序列:,res)

结果:

技术图片

 

最长升序列 DP

标签:on()   image   http   info   img   nbsp   com   结果   elf   

原文地址:https://www.cnblogs.com/missidiot/p/11505075.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!