【数字三角形】

题目描述

上图给出了一个数字三角形。从三角形的顶部到底部有很多条不同的路径。对于每条路径,把路径上面的数加起来可以得到一个和,你的任务就是找到最大的和。

路径上的每一步只能从一个数走到下一层和它最近的左边的那个数或者右 边的那个数。此外,向左下走的次数与向右下走的次数相差不能超过 1。

输入描述

输入的第一行包含一个整数 N (1 ≤ N ≤ 100),表示三角形的行数。

下面的 N 行给出数字三角形。数字三角形上的数都是 0 至 100 之间的整数。

输出描述

输出一个整数,表示答案。

输入输出样例

示例

输入:

5

7

3 8

8 1 0

2 7 4 4

4 5 2 6 5

输出:

27

运行限制

最大运行时间:1s

最大运行内存: 256M

python 复制代码
num=int(input())
mapp=[]
for item in range(num):
    data=list(map(int,input().split()))
    mapp.append(data)
    pass
dp=[[0 for i in range(0,j+1)]for j in range(num)]
for item in range(num):
    for jtem in range(item+1):
        if item==jtem==0:
            dp[item][jtem]=mapp[0][0]
            pass
        if jtem==0:
            dp[item][jtem]=mapp[item][jtem]+dp[item-1][jtem]
            pass
        elif jtem==item:
            dp[item][jtem]=mapp[item][jtem]+dp[item-1][jtem-1]
            pass
        else:
            dp[item][jtem]=max(mapp[item][jtem]+dp[item-1][jtem-1],mapp[item][jtem]+dp[item-1][jtem])
            pass
        pass
    pass
if num%2==0:
    anss=max(dp[num-1][(num)//2],dp[num-1][(num)//2-1])
    pass
else:
    anss=dp[num-1][(num)//2]
    pass
print(anss)

题目中左右步数相差不超过一,则说明了最后的答案一定是处于中间的,//表示做除法后向下取整

相关推荐
小O的算法实验室8 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生9 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿9 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz9 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能9 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****9 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能9 小时前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能9 小时前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo10 小时前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ010 小时前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法