python - 求金字塔/三角形中相邻数字的最大和时输出错误

标签 python python-3.x algorithm data-structures dynamic-programming

我解决Problem 18 on Project Euler并为其编写了如下代码:

v = '''75
95 64
17 47 82
18 35 87 10
20 04 82 47 65
19 01 23 75 03 34
88 02 77 73 07 63 67
99 65 04 28 06 16 70 92
41 41 26 56 83 40 80 70 33
41 48 72 33 47 32 37 16 94 29
53 71 44 65 25 43 91 52 97 51 14
70 11 33 28 77 73 17 78 39 68 17 57
91 71 52 38 17 14 91 43 58 50 27 29 48
63 66 04 68 89 53 67 30 73 16 69 87 40 31
04 62 98 27 23 09 70 98 73 93 38 53 60 04 23'''.strip().split('\n')


last_ind = 0
max_sum = 75
for row in v[1:]:
    row = row.split(' ')
    num1 = int(row[last_ind])
    num2 = int(row[last_ind+1])
    if num1 > num2:
        max_sum+=num1
    else:
        max_sum+=num2
        last_ind = last_ind+1
        
print(max_sum)    

我得到的答案是1064,但到处都写着1074。有人可以建议我我可能做错了什么吗?通过手动计算每一行,我得到1064。这里出了什么问题?

最佳答案

您假设最佳路径始终会通过具有最大值的子路径向下移动,但事实并非如此。具有较小值的子项可能会(在较低层)找到更大值的可能性,这足以补偿暂时的次优值。

因此,您的算法在第一次迭代中将从第二行的 75 变为 95。但事实证明这是错误的选择。你必须想出一个更好的算法。您将在有关这一特定挑战的其他问答中找到灵感,例如this one .

在这里您可以看到最佳路径:

<表类=“s-表”> <标题> 路径 <正文> 75 95 64 17 47 82 18 35 87 10 20 04 82 47 65 19 01 23 75 03 34 88 02 77 73 07 63 67 99 65 04 28 06 16 70 92 41 41 26 56 83 40 80 70 33 41 48 72 33 47 32 37 16 94 29 53 71 44 65 25 43 91 52 97 51 14 70 11 33 28 77 73 17 78 39 68 17 57 91 71 52 38 17 14 91 43 58 50 27 29 48 63 66 04 68 89 53 67 30 73 16 69 87 40 31 04 62 98 27 23 09 70 98 73 93 38 53 60 04 23

关于python - 求金字塔/三角形中相邻数字的最大和时输出错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66731942/

相关文章:

python - 我怎样才能改进这个方程,使负面投票多于正面投票的项目返回更有用的威尔逊分数

python - pandas rolling 和 ewm 完全忽略 na 并使用最后 N 个有效数据

python - 在 CentOS 上为 Python3 编译 C 扩展

algorithm - 使用基于决策树比较的模型证明下限

arrays - 比较排序数组的算法

python - 有没有办法使用列表理解来计算特定条件下按元素分组的频率,但不计算其他元素的频率?

python - 从 URL 列表(每个 URL 包含一个唯一的表)中抓取表数据,以便将其全部附加到单个列表/数据帧中?

python - 在 Python 中模糊查找扑克翻牌

python - 如何在 python 3 中将字符串添加到 json 值

algorithm - 查找数组中重复的三元组