有关斐波那契序列生成器的问题-什么都没打印

时间:2018-11-21 23:42:01

标签: python fibonacci

在我的课堂上给我一个赋值,我需要写一个算法来生成斐波那契数列的“ 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)

1 个答案:

答案 0 :(得分:2)

此修复程序看起来很简单。 while循环中的分组是错误的,请将其更改为以下内容,然后应该可以正常工作:

while((zints.int4<hwmny)or not(zints.int4>0)and not(zints.int4==0)):