解题思路:
动态规划。
注意事项:
走的路线从下到上只能走上面的或左上面。
参考代码:
n = int(input()) mapL = [list(map(int,input().split())) for _ in range(n)] dp = [] for i in range(n): dp.append([0]*(i+1)) dp[0][0] = mapL[0][0] for i in range(1,n): for j in range(0,len(mapL[i])): if j == 0: dp[i][j] = dp[i-1][j] + mapL[i][j] elif j == len(mapL[i]) - 1: dp[i][j] = dp[i-1][j-1] + mapL[i][j] else: dp[i][j] = max(dp[i-1][j],dp[i-1][j-1]) + mapL[i][j] print(max(dp[n-1]))
0.0分
3 人评分
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:575 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:262 |
DNA (C语言描述,蓝桥杯)浏览:1553 |
DNA (C语言代码)浏览:540 |
C语言程序设计教程(第三版)课后习题9.4 (C语言代码)浏览:664 |
1908题解浏览:633 |
1642题解浏览:708 |
sizeof的大作用 (C语言代码)浏览:1448 |
C语言程序设计教程(第三版)课后习题9.3 (C语言代码)浏览:668 |
C语言程序设计教程(第三版)课后习题10.1 (C语言代码)浏览:530 |