我正在练习动态编程 我也是python的新手。 当我在shell中尝试这个。
def cut_rod(p, n):
if n==0:
return 0
q = float('-inf')
for i in range(n):
q = max(q, p[i] + cut_rod(p, n-1-i))
return q
p = [1,5,8,9,10,17,17,20,24,30]
print(timeit.repeat("cut_rod(p, 4)", "from __main__ import cut_rod",
number =1000))
它警告我p不是全局变量。在timeit功能 p不是已经是全局变量吗?
答案 0 :(得分:2)
问题是您没有导入p
:
print(timeit.repeat("cut_rod(p, 4)", "from __main__ import cut_rod, p",
number =1000))
timeit
在受控环境中执行代码,因此您必须显式传递语句所需的所有内容。