python中的斐波那契数列给出了奇怪的结果

时间:2015-04-30 03:58:14

标签: python python-3.x

我已经开始学习python,我的第一个关于斐波纳契的程序开始给我一些奇怪的答案,我知道我在概念上缺少某些东西所以需要一些专家的指导。我的程序看起来像这样

#! usr/bin/python
a,b = 0, 1
while (b < 50):
    print(b)
    a = b
    b = a + b 

输出

1
2
4
8
16
32

但是当我这样写的时候我得到了正确的结果

#! usr/bin/python
a,b = 0, 1
while (b < 50):
    print(b)
    a,b = b, a + b

输出:

1
1
2
3
5
8
13
21
34

指导我[/ p>]

1 个答案:

答案 0 :(得分:6)

a,b = 0,1
a = b          # a <- 1
b = a + b      # b <- a + b (1 + 1 = 2)

这是两个单独的操作,其中最后一行中的a在使用前已经被修改过。

另一方面:

a,b = b, a + b

是一个原子操作,其中=右侧的所有内容都是原始值。

因此它相当于:

a,b = 0,1
t = a          # t <- 0
a = b          # a <- 1
b = t + b      # b <- t + b (0 + 1 = 1)