Python实现杆切割算法

时间:2013-05-17 12:09:54

标签: python debugging

我正在练习动态编程 我也是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不是已经是全局变量吗?

1 个答案:

答案 0 :(得分:2)

问题是您没有导入p

print(timeit.repeat("cut_rod(p, 4)", "from __main__ import cut_rod, p",
              number =1000))

timeit在受控环境中执行代码,因此您必须显式传递语句所需的所有内容。