题解 | 动态规划#Redraiment的走法#

Redraiment的走法

http://www.nowcoder.com/practice/24e6243b9f0446b081b1d6d32f2aa3aa

假设 dp[i]为终点为第i个桩的最大走法

那么比较之前num[j]中比num[i]小的桩的最大走法:

如果 num[j]< num[i],那么就有两种情况:

  1. 踩上j桩: dp[i] = 1 + dp[j]
  2. 不踩,忽略: dp[i] = dp[i] (原数量不变)

取两个情况的最大值

while True:
    try:
        n = int(input())
        s = list(map(int,input().split()))
        dp= [1] *n
        for i in range(n):
            for j in range(i):
                if s[i]>s[j]:
                    dp[i] = max(1+dp[j],dp[i])
        print(max(dp))
    except:
        break
        
        
全部评论

相关推荐

无情咸鱼王的秋招日记之薛定谔的Offer:好拒信,偷了,希望有机会用到
点赞 评论 收藏
分享
没有offer的小土豆:专业面试一般是分配面试官然后联系你面试 应该是还没给你分配对应面试官
点赞 评论 收藏
分享
评论
31
6
分享
牛客网
牛客企业服务