【发布时间】:2020-01-18 18:47:15
【问题描述】:
我正在开发一个程序,该程序将计算具有某些数字限制的斐波那契数(即第一个具有 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]
【问题讨论】:
-
缺少 num1 的定义。是否为num2(除了右边全为0)?
-
它在里面,一定不是每次我抓取代码粘贴到这里时都复制它。我将进行编辑,以便更清楚。
-
@LukeMorris,我不太清楚你的输出应该是什么?你能在你的问题中澄清一下吗?
-
错误已经出现在 num2 = 8 和 num1 = 5 时,在第一次进位时:在 count = 1 时将 num2 修改为 13,然后在 count = 2 时使用该 1(进位)来总和到 num1 得到 15 而不是 8 如预期的那样。使用调试器 ;-) 我猜你可能记得有一个进位并在下一次计数时减去它,或者你需要改变你的逻辑来更新新的 1 和 2
-
我会说,记住在下一个循环中要添加进位,但不要在当前数字中添加。这应该是最好的!