题解 | #合唱队#

合唱队

http://www.nowcoder.com/practice/6d9d69e3898f45169a441632b325c7b4

def DPPPPPPPPPP(l):
    LIS=[1]*len(l)
    for i in range(1,len(l)):
        for j in range(i):
            if l[i]>l[j]:
                LIS[i]=max(LIS[i],LIS[j]+1)
    return LIS
while True:
    try:
        num = int(input())
        stu_list = list(map(int,input().split()))
        count=[]
        left = DPPPPPPPPPP(stu_list)
        right = DPPPPPPPPPP(stu_list[::-1])[::-1]
        for i in range(len(left)):
            count.append(left[i]+right[i]-1)
        print(num-max(count))
    except:
        break
全部评论
不会超时吗?
点赞 回复 分享
发布于 2022-01-29 18:25
运行超时
点赞 回复 分享
发布于 2022-02-12 21:55
超时就用二分法吧,这种dp还是太初级了
点赞 回复 分享
发布于 2022-02-25 17:33
把函数名改一下,只剩下DP,就不会超时了。很赞、很直观的一个思路!
点赞 回复 分享
发布于 2022-07-03 16:40

相关推荐

10-30 22:18
已编辑
毛坦厂中学 C++
点赞 评论 收藏
分享
点赞 评论 收藏
分享
15 3 评论
分享
牛客网
牛客企业服务