在最近学的Python斐波那契数列(Fibonacci sequence)中遇到了这么一个奇怪的赋值计算方式,a , b =b ,a + b:
源代码如下:
import sys
def Fibonacci(k):
a = 0
b = 1
count = 0
while True:
if(count > k):
return
yield a
a,b=b,a+b
count+=1
def testPrint(data):
Fou = Fibonacci(data) #注:F为yield生成器返回生成的迭代器,相当于iter()
while True:
try:
print(next(Fou), end = " ")
except StopIteration:
sys.exit()
testPrint(10)
输出结果如是:
D:Program FilesPython37python.exe" E:/python/LearnProject/FileOpration.py
0 1 1 2 3 5 8 13 21 34 55
进程已结束,退出代码0
将以上源代码中a , b = b ,a + b 换成 a = b , b = a + b后,效果如下:
部分切换后的源代码:
结果如下:
"D:Program FilesPython37python.exe" E:/python/LearnProject/FileOpration.py
0 1 2 4 8 16 32 64 128 256 512
进程已结束,退出代码0
分析
a = 0
b = 1
count = 0
初始赋值如上所示,count记录循环次数。
进入循环:
对于a , b = b ,a + b :
- 计算过程:首先计算b = b ,a + b,即 b = b = 1, a +b = 0 + 1 = 1 ;
- 接下来赋值: a = b = 1;
- 继续循环重复以上步骤,请拿出笔自行演算或参见以上输出结果。
对于a = b , b = a + b :
- 这是最为常见的赋值计算式,计算过程:首先赋值 a = b = 1;
- 接下来计算: b = a + b = 1 + 1 = 2;
- 注意到这里两个式子结果已经不同,导致了以上第二次输出情况。
- 继续循环重复以上步骤,请拿出笔自行演算或参见以上输出结果。
Comments NOTHING