题目:斐波那契数列
来源:互联网 发布:java 线程池 等待队列 编辑:程序博客网 时间:2024/06/06 03:15
程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。
小白我尝试根据大神们的博客自己编程发现自己未曾理解的一个小知识点,大神请绕行,小白接着看哈。嘿嘿
(转载)解法:
def fib(n):
a,b=1,0
for i in range(n):
a,b=b,a+b
print(a)
fib(10)
结果:
0
1
1
2
3
5
8
13
21
完美解决,但是当我尝试自己编写时,我发现无法实现,输出结果完全不同
def fib(n): a=1 b=0 for i in range(n - 1): a=b b=a + b print(a)# 输出了第10个斐波那契数列fib(10)
输出结果:
000000000为什么出现这种结果呢,表面看我什么都没有改变啊,编程逻辑是一样的,问题就出现在这个看似一样的编程逻辑上
a,b=b,a+b
与
a=b
b=a+b是不一样的
例如:
a=1
b=0
a,b=b,a+b
print(a,b)
结果:a=0 b=1
a=1
b=0
a=b
b=a+b
print(a,b)
结果:a=0,b=0
输出结果是不一样的,看懂了嘛
a,b=b,a+b
是先执行等号=右边的式子,之后再赋值给左边的变量,也就是说b=a+b=1+0=1,所以b=1
阅读全文
1 0
- 题目4:斐波那契数列
- 题目1075:斐波那契数列
- 题目1075:斐波那契数列
- 题目1387:斐波那契数列
- 题目1387:斐波那契数列
- 题目1387:斐波那契数列
- 题目1387:斐波那契数列
- 题目1387:斐波那契数列
- 题目1075:斐波那契数列
- 题目1387:斐波那契数列
- 题目1387:斐波那契数列
- 编程题目:斐波那契数列
- 题目9:斐波那契数列
- 题目1075:斐波那契数列
- 题目1075:斐波那契数列
- 题目1387:斐波那契数列
- 算法题目---斐波那契数列
- 题目:斐波那契数列
- Java try和catch的使用
- Android Studio 3.0 gradle提示太老 解决方法
- raspberry 3b 64bit 系统安装,以及交叉编译环境、调试环境的搭建
- 网络中获取json数据
- sqlite迁移到mysql脚本
- 题目:斐波那契数列
- Ionic初学习上遇到的问题
- 并查集
- 小白教你学习C++(9)文件流操作
- UE4 AI行为树简记
- seafile 迁移手册
- Struts2项目实战 微云盘(一):项目分析
- Java 注解1
- java图片处理以及pdf转图片