题解 | 数字三角形

数字三角形

https://www.nowcoder.com/practice/c0848016f7024077ab12c75081972402

import sys
n=int(input())
data=list(sys.stdin.read().splitlines())
matrix = list(list(map(int,item.split())) for item in data)
#从第2层开始遍历
for i in range(1,n):
    #选取其正上方或左上方的最大值相加,更新当前层所有元素数值
    for j in range(len(matrix[i])):
        #当位于对角线的元素没有正上方元素,所以不能加上
        #当位于第一列的元素左上方没有元素,也不能加
        matrix[i][j]+=max(matrix[i-1][j] if j<i else -10**5,matrix[i-1][j-1] if j!=0 else -10**5)
#选取最后一层的最大值,即为答案
print(max(matrix[-1]))

全部评论

相关推荐

01-17 11:57
已编辑
门头沟学院 前端工程师
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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