我必须编写一个函数来计算并返回我们可以从知识库中获得的最大收益,该知识库按级别存储在列表列表中。
要测试此功能,主要是:
if __name__ == "__main__":
l0 = [[7], [3,8], [8,1,0], [2,7,4,4], [4,5,2,6,5]]
l1 = [[11], [7,32], [14,14,14], [0,1,2,3], [5,99,1,2,7],
[0,25,9,45, 54,1], [99,88,77,66,55,44,33]]
>>>30
>>>270
我试着从下往上开始,有没有其他的解决办法?
你可以把列表想象成一棵树
[7]
[3,8]
[8,1,0]
[2,7,4,4]
依此类推...我想达到最大收益的步行,选择的权重由列表中的数字给出,我必须最大化我的路径
我已经写了这个解决方案
def maxpath(listN):
liv = len(listN) -1
return calcl(listN,liv)
def calcl(listN,liv):
if liv == 0:
return listN[0]
listN[liv-1] = [(listN[liv-1][i]+listN[liv][i+1],listN[liv-1][i]+listN[liv][i]) \
[ listN[liv][i] > listN[liv][i+1] ] for i in range(0,liv)]
return calcl(listN,liv-1)
print(maxpath(l0))
print(maxpath(l1))
#output
[30]
[270]