>>> def gcd(m,n):
if m%n==r and n !=0 and r !=0:
return gcd(m,n)==gcd(n,r)
elif n==0 or r==0:
return gcd(m,0)==1
else:
print Nonegcd(5,6)
Traceback (most recent call last):
File "<pyshell#35>", line 1, in <module>
gcd(5,6)
File "<pyshell#34>", line 5, in gcd
return gcd(m,0)==1
File "<pyshell#34>", line 2, in gcd
if m%n==r and n !=0 and r !=0:
ZeroDivisionError: integer division or modulo by zero抱歉,我刚把它修改成另一个版本,但还是收到了类似的错误信息.感谢你们所有人!
发布于 2012-05-29 20:32:28
我怀疑您在发布此问题时将粘贴的代码从gcd(5,0)更改为gcd(5,6)。
您对gcd的调用是传递值5和0,正如您的错误消息所指示的那样。线if m%n==r:试图用0除法--这在数学上是不可能的.这就是ZeroDivisionError异常的原因。
编辑:
格式化是关闭的,所以我在第一次传递时就忽略了这一点,但是在r=int()行中,您将r设置为0。这意味着这一行return gcd(m,n)==gcd(n,r)将0传递给gcd。
https://stackoverflow.com/questions/10806259
复制相似问题