在我的课堂上给我一个赋值,我需要写一个算法来生成斐波那契数列的“ n”个数字。
我觉得这段代码应该可以正常工作,但是在查找阻止其正常工作的错误方面仍然遇到麻烦。
该算法应开始打印从数字2
开始的斐波那契数列(前3个数字已打上补丁),但它仅打印前3个数字,而我的算法不打印任何内容。
我什至拥有复杂的错误检查功能,可以排除错误的值,但是它也不报告任何内容。
#/usr/bin/python
import re
import math
import time
import sys
def errchk(hwmny,int1,int2,int3,int4,errcnt):
#Sanity check; first 12 numbers don't have 6's
expression = re.compile(r"^[^6]{1,3}", re.I | re.S) #expression for no sixes
if expression.match(str(int3)): # if it doesn't match
return # return
else: #otherwise
if (hwmny > 12): # as long as it's less than 12
return # no errors
zints.err() #but ifnot, errors
return None
def nofloats():
return math.floor(zints.int3)
class zeroints:
int3=int4 = 0 #int3 and int4 are 0
errcnt = 0 #count the number of errors
def err(self):
print "Errors"
return
hwmny =15 #hwmny variable is 10
int1 =int2 =1 #int1 and int2 are 1
zints = zeroints() #ints init'd to 0
print "0\n1\n1"
def loop(hwmny,int1,int2,int3,int4,errcnt):
while(((zints.int4<hwmny)or not(zints.int4>0))and not(zints.int4==0)): #while int4 is less than hwmny and error checking
zints.int3 =int1+ int2 #int3 is int1 plus int2
int1 =int2 #int1 is int2
string = 'The Values Are' #string is set to 'The Values Are'
int2= zints.int3 #int2 is int3
errchk(hwmny,int1,int2,zints.int3,zints.int4,zints.errcnt)
print zints.int3 #print int3
zints.int4= zints.int4+1 #int4 is int4 plus 1
loop(hwmny,int1,int2,zints.int3,zints.int4,zints.errcnt)
continue
loop(hwmny,int1,int2,zints.int3,zints.int4,zints.errcnt)
答案 0 :(得分:2)
此修复程序看起来很简单。 while循环中的分组是错误的,请将其更改为以下内容,然后应该可以正常工作:
while((zints.int4<hwmny)or not(zints.int4>0)and not(zints.int4==0)):