python - 斐波那契加法器 - 计算斐波那契数列中的数字

标签 python loops fibonacci

我正在开发一个程序,该程序将计算具有某些数字限制的斐波那契数(即第一个具有 100 位数字的斐波那契数)。我下面的代码总体正在运行,但我遇到了一个让我难倒的逻辑错误。

代码的目标是以类似于二进制加法的方式计算斐波那契数。使用数组时,每个元素都保存 0 - 9 之间的数字,因此每个数组索引代表 10 的位置。

它开始正常工作并循环,但由于循环的处理方式,它在 13 到 21 之间停止。它将 10 位的数字相加,然后保存一个 31 数字。

有没有办法打破或阻止它把我没有看到的那些加在一起?

num1 = [0]*100
num2 = [0]*100
num2[len(num2)-1] = 1
carry = 0
flag = True

while (flag):
    #Main for loop to work through the array
    for count in range (1, len(num2)):
        carry = num2[len(num2) - count] + num1[len(num1) - count]
        if carry > 9:
            num2[len(num2)- (count + 1)] = num2[len(num2)- (count + 1)] + 1
            carry = carry % 10
            num1[len(num1) - count] = num2[len(num2) - count]
            num2[len(num2) - count] = carry
        else:
            num1[len(num1) - count] = num2[len(num2) - count]
            num2[len(num2) - count] = carry
    print(num2)
    if num2[0] != 0:
        flag = False

每次它通过主 while 循环时我都希望看到

[0,0,...,0,1]
[0,0,...,0,2]
[0,0,...,0,3]
[0,0,...,0,5]
[0,0,...,0,8]
[0,0,...,1,3]
[0,0,...,2,1]
...

但在到达 [...,2,1] 循环后,它会移动到 [...,3,1]

最佳答案

这是我相信您想要了解的内容的一个更清晰的版本。

#Init of Fib variables 
a = 0
b = 1
num = 10  #Change this to the number of fib calculation loops.
x = 0
output_arr_len = 100 #Change this to 10 for testing, as it's easier to see.    

while x < num:
    #Calculate Fib Sequence
    c = a + b 
    a = b
    b = c 
    x += 1

    #Output Array
    print([0] * (output_arr_len - len(str(c))) + [int(i) for i in str(c)])

下面是前 20 个循环的输出,其中 output_arr_len 设置为 10。

[0, 0, 0, 0, 0, 0, 0, 0, 0, 1]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 2]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 3]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 5]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 8]
[0, 0, 0, 0, 0, 0, 0, 0, 1, 3]
[0, 0, 0, 0, 0, 0, 0, 0, 2, 1]
[0, 0, 0, 0, 0, 0, 0, 0, 3, 4]
[0, 0, 0, 0, 0, 0, 0, 0, 5, 5]
[0, 0, 0, 0, 0, 0, 0, 0, 8, 9]
[0, 0, 0, 0, 0, 0, 0, 1, 4, 4]
[0, 0, 0, 0, 0, 0, 0, 2, 3, 3]
[0, 0, 0, 0, 0, 0, 0, 3, 7, 7]
[0, 0, 0, 0, 0, 0, 0, 6, 1, 0]
[0, 0, 0, 0, 0, 0, 0, 9, 8, 7]
[0, 0, 0, 0, 0, 0, 1, 5, 9, 7]
[0, 0, 0, 0, 0, 0, 2, 5, 8, 4]
[0, 0, 0, 0, 0, 0, 4, 1, 8, 1]
[0, 0, 0, 0, 0, 0, 6, 7, 6, 5]
[0, 0, 0, 0, 0, 1, 0, 9, 4, 6]

关于python - 斐波那契加法器 - 计算斐波那契数列中的数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57982123/

相关文章:

c++ - 如何在 log(n) 或更短时间内计算此序列的第 n 个元素?

python - 如何从其他模块导入生菜步骤?

python - Linux通过弹出密码获取root权限

python - 使用 Python 制作包含 100 多个图的 PDF 报告的最佳方式是什么?

python - python在导入模块时如何加载*.so

c - 当用户输入 "quit"时使 while 循环不打印(在用户说退出但程序结束后仍打印 STR)

javascript - 如何创建一个由订单号 : array within array, 宾果卡和循环陷阱组成的正方形......

javascript - 我可以使用 "map"代替 "for each"/"for in"吗?

C++错误,添加偶数

Python:创建前 n 个斐波那契数列