0

我从这个问题中得到的这个功能如下:

def f(n, p, k, t):
    return sum(sum(1 if n == 3 else
                   (0 if k == 1 else
                    (1/36) * f(n-1, p, k-1, t-(max(p,i)))
                    for i in xrange(1, 7)))
                   for p in xrange(1, 7))

print sum(f(5,j,3,15) for j in xrange(1, 7))

当我运行它时,我得到这个以以下结尾的长回溯错误序列:

File "C:/Users/r/Documents/school/IB/Computer Science HL/Other Languages/Problem240/Problem240 - recursive2.py", line 6, in <genexpr>
for p in xrange(1, 7))
TypeError: 'int' object is not iterable

有人可以告诉我发生了什么吗?我的代码有什么问题,我该如何解决?谢谢!

4

2 回答 2

2

我想你的意思是

def f(n, p, k, t):
    return sum(sum(1 if n == 3 else
                   (0 if k == 1 else
                    (1/36) * f(n-1, p, k-1, t-(max(p,i)))) # <- more here
                   for i in range(1, 7)) # <- less here
               for p in range(1, 7))

print(sum(f(5,j,3,15) for j in range(1, 7)))

(我使用的是python 3,但基本相同)。

您有一些括号错误,因此内部总和不是您期望的生成器表达式。

由于您使用的是 python 2,因此还请参阅下面 gnibbler 的观点

于 2013-02-21T00:48:54.350 回答
1

如果您无法理解自己的代码,请将其分解为更小的部分

def f(n, p, k, t):
    ternary = (1 if n == 3 else 0 if k == 1 else 
        f(n-1, p, k-1, t-max(p,i))/36.0 for i in range(1, 7))

    inner_sum = sum(ternary)
    return sum(inner_sum for p in range(1, 7))
于 2013-02-21T00:57:29.960 回答