[英]Fibonacci sequence multiplying
我试图用以下代码制作斐波那契数列:
def fibonacci(n): # write Fibonacci series up to n
"""Print a Fibonacci series up to n."""
a = 0
b = 1
the_list = []
while n > len(the_list):
the_list.append(a)
#By saying a = b and b = a+b we define the
#fibonacci sequence, since this is how the
#fibonacci sequence works.
a = b
b = a+b
print the_list
# Now call the function we just defined:
fibonacci(10)
据我所知,该代码应该执行此操作,但与其给我斐波那契序列,不如给出以下输出:
[0, 1, 2, 4, 8, 16, 32, 64, 128, 256]
所以我的斐波那契数列是乘法而不是正确地工作。 我不知道为什么,因为我想
a = b
b = a+b
应该可以解决问题,如果我看看我的while循环,这个循环的语句也是正确的,所以我只是不明白为什么我没有得到正确的输出。
因此,如果有人可以向我解释为什么此代码无法正常工作,那么它会受到高度重视。
由于逻辑缺陷,您的代码正在创建指数序列。 根据您的代码:
Start:
a = 0
b = 1
1st iteration:
a = b = 1
b = a + 1 = 1 + 1 = 2
2nd iteration:
a = b = 2
b = a + 2 = 2 + 2 = 4
如您所见,在执行b
计算之前设置a
会导致问题。
相反,您需要以下内容(证明这一点):
tmp = a
a = b
b = tmp + a
进行一些额外的数学运算将消除对额外变量的需要:
b += a
a = b - a
但是最简单(也是最pythonic)的方式是:
a, b = b, a + b
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.