题解 | #Redraiment的走法#

Redraiment的走法

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

转化为求最长升序子序列长度

while True:
    try:
        num = int(input())
        lst = list(map(int,input().split()))
        l = len(lst) #序列长度
        if(l == 1):
            print(1)
        else:
            data = [1]*l #记录每个数字的前面的最长升序子序列
            for i in range(1,l): #从第二个数字开始
                for j in range(i): #从第一个数字开始到第i+1个
                    if(lst[i] > lst[j]):  #若找到的数字小于第i+1个数字
                        data[i] = max(data[i],data[j] + 1) #data记录的是当前数字之前的公共子序列长度
        print(max(data))
    except:
        break
华为机试题解(prod.by kedao) 文章被收录于专栏

华为实习机试题解

全部评论

相关推荐

程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
菜菜狗🐶:双非之光
找工作,你会甘心进小厂还...
点赞 评论 收藏
分享
评论
8
3
分享

创作者周榜

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