Python实现 - 斐波那契数列与函数的增长
off999 2024-10-23 12:39 44 浏览 0 评论
微实践 - 一对兔兔与函数的增长
数学家列昂纳多·斐波那契研究了野外兔子的繁殖问题:一般而言,兔子出生两个月后,就有繁殖能力。假设一对兔子每个月能生出一对小兔子而且所有兔子都不死。如果现在往一片没有兔子的新大陆上放生一对新生的兔子,那么一年以后那个大陆上有多少只兔子?两年以后呢?
第1个月,那对兔子还没有繁殖能力,仍为幼兔。故幼兔数量为1对,成兔数量为0对,总对数为1;
第2个月,那对兔子性成熟,变成成兔。故幼兔数量为0对,成兔数量为1对,总对数为1;
第3个月,2月时的成兔1对,生了1对小兔子,故幼兔1对,成兔1对,总对数为2;
第4个月,3月时的成兔1对生了1对小兔子,且3月时的幼兔1对变成了成兔,故幼兔数量为1对,成兔变成了2对,总对数为3...
简单归纳,容易导出下述结论:
幼免对数 = 前月成兔对数 (每对成兔每月生一对小兔子)
成兔对数 = 前月成兔对数 (成兔不死) + 前月幼兔对数(前月的幼兔长大变成成兔)
总对数 = 幼兔对数 + 成兔对数
观察上述表格,可以发现,上述三行数据,在1,1后的每一个数字,都正好等于前两个数字之和。2 = 1 + 1, 3 = 1+2, 5 = 2 + 3... 89 = 34 + 55...
本文节选自作者的《Python编程基础及应用》视频教程。
Python编程基础及应用_哔哩哔哩 (゜-゜)つロ 干杯~-bilibiliwww.bilibili.com
斐波那契对上述规律进行总结和形式化,得到关于n个月后兔子数量的通项公式如下,这是一个分段函数。
读者希望知道10年,也就是120个月之后的兔子数量吗? 我们来计算一下。
[fib1.py]
def fibonacci(n):
if n <= 2:
return 1
a,b = 1,1 #最近两项的值,a为前前项,b为前项
for x in range(3,n+1):
v = a + b #新值 = 前两项之和
a,b = b,v #a = b, b = v
return v
for n in range(1,121): #121确保数值列表包括120
print("month:",n,"rabbits:",fibonacci(n))
执行结果:
month: 1 rabbits: 1
month: 2 rabbits: 1
month: 3 rabbits: 2
...
month: 8 rabbits: 21
...
month: 23 rabbits: 28657
...
month: 38 rabbits: 39088169
...
month: 54 rabbits: 86267571272
...
month: 75 rabbits: 2111485077978050
...
month: 120 rabbits: 5358359254990966640871840
函数fibonacci(n)计算并返回第n个月后的免子对数。计算结果几乎是反直觉的。如果这块新大陆无限大,食物无限丰富,而且没有灰太狼,那么120个月以后,兔子的总对数为:5358359254990966640871840。恭喜成都的朋友们,他们拥有了"永远"也啃不完的麻辣兔头。
上述fibonacci函数值随参数的增长速度极其惊人。在计算复杂性问题上,研究函数的值随参数的增长速度,是有一件有趣的事情。接下来,我们比较一下下述函数以及斐波那契函数随参数的增长速度:
#grow.py
def fibonacci(n):
if n <= 2:
return 1
a,b = 1,1 #最近两项的值,a为前前项,b为前项
for x in range(3,n+1):
v = a + b #新值 = 前两项之和
a,b = b,v #a = b, b = v
return v
x = list(range(1,11)) #1..10的数值列表
n2,n3,fn = [],[],[] #依次为n的平方,n的立方,n值斐波那契
for v in x: #依次计算机各函数值
n2.append(v*v)
n3.append(v*v*v)
fn.append(fibonacci(v))
print("n^2=",n2)
print("n^3=",n3)
print("fib(n)=",fn)
from matplotlib import pyplot as plt #绘图部分
plt.plot(x,n2,color='black',label="$y=n^2#34;)
plt.plot(x,n3,linestyle="-.",color='black',label="$y=n^3#34;)
plt.plot(x,fn,linestyle="--",color='black',label="$y=fibonacci(n)#34;)
plt.legend()
plt.show()
执行结果:
n^2= [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
n^3= [1, 8, 27, 64, 125, 216, 343, 512, 729, 1000]
fib(n)= [1, 1, 2, 3, 5, 8, 13, 21, 34, 55]
上述代码首先生成了一个x列表,其值为[1,2,3,4,5,6,7,8,9,10];然后对x列表每一个值,逐一计算其平方,立方及斐波那契函数的值。最后使用matplotlib将四个函数绘制出来。matplotlib是一个绘图用的扩展模块,需要通过在命令行中执行pip install matplotlib进行安装。
下图展示了参数取值1-10时,3个函数的增长曲线图:
看起来,n3增长较快,n2和fibonacci(n)增长较慢。这不是事实! 我们把参数取值范围扩大到1-30,重新绘图,结果如下:
可以看到,斐波那契函数的增长曲线昂首挺胸,而n平方以及n立方在该尺度下,几乎趴在了地上。读者可以自行试验一下x取值1-100的情况。
相对于斐波那契函数,n3的增长速度实在是太慢了。从数学上讲,斐波那契函数与n3都是n趋近于无穷大时的无穷大,但显而易见,斐波那契函数拥有更高的阶。
版权声明 本文可以在互联网上自由转载,但必须:注明出处(作者:海洋饼干叔叔)并包含指向本页面的链接。 本文不可以以纸质出版为目的进行改编、摘抄。
相关推荐
- python入门到脱坑经典案例—清空列表
-
在Python中,清空列表是一个基础但重要的操作。clear()方法是最直接的方式,但还有其他方法也可以实现相同效果。以下是详细说明:1.使用clear()方法(Python3.3+推荐)...
- python中元组,列表,字典,集合删除项目方式的归纳
-
九三,君子终日乾乾,夕惕若,厉无咎。在使用python过程中会经常遇到这四种集合数据类型,今天就对这四种集合数据类型中删除项目的操作做个总结性的归纳。列表(List)是一种有序和可更改的集合。允许重复...
- Linux 下海量文件删除方法效率对比,最慢的竟然是 rm
-
Linux下海量文件删除方法效率对比,本次参赛选手一共6位,分别是:rm、find、findwithdelete、rsync、Python、Perl.首先建立50万个文件$testfor...
- 数据结构与算法——链式存储(链表)的插入及删除,
-
持续分享嵌入式技术,操作系统,算法,c语言/python等,欢迎小友关注支持上篇文章我们讲述了链表的基本概念及一些查找遍历的方法,本篇我们主要将一下链表的插入删除操作,以及采用堆栈方式如何创建链表。链...
- Python自动化:openpyxl写入数据,插入删除行列等基础操作
-
importopenpyxlwb=openpyxl.load_workbook("example1.xlsx")sh=wb['Sheet1']写入数据#...
- 在Linux下软件的安装与卸载(linux里的程序的安装与卸载命令)
-
通过apt安装/协助软件apt是AdvancedPackagingTool,是Linux下的一款安装包管理工具可以在终端中方便的安装/卸载/更新软件包命令使用格式:安装软件:sudoapt...
- Python 批量卸载关联包 pip-autoremove
-
pip工具在安装扩展包的时候会自动安装依赖的关联包,但是卸载时只删除单个包,无法卸载关联的包。pip-autoremove就是为了解决卸载关联包的问题。安装方法通过下面的命令安装:pipinsta...
- 用Python在Word文档中插入和删除文本框
-
在当今自动化办公需求日益增长的背景下,通过编程手段动态管理Word文档中的文本框元素已成为提升工作效率的关键技术路径。文本框作为文档排版中灵活的内容容器,既能承载多模态信息(如文字、图像),又可实现独...
- Python 从列表中删除值的多种实用方法详解
-
#Python从列表中删除值的多种实用方法详解在Python编程中,列表(List)是一种常用的数据结构,具有动态可变的特性。当我们需要从列表中删除元素时,根据不同的场景(如按值删除、按索引删除、...
- Python 中的前缀删除操作全指南(python删除前导0)
-
1.字符串前缀删除1.1使用内置方法Python提供了几种内置方法来处理字符串前缀的删除:#1.使用removeprefix()方法(Python3.9+)text="...
- 每天学点Python知识:如何删除空白
-
在Python中,删除空白可以分为几种不同的情况,常见的是针对字符串或列表中空白字符的处理。一、删除字符串中的空白1.删除字符串两端的空白(空格、\t、\n等)使用.strip()方法:s...
- Linux系统自带Python2&yum的卸载及重装
-
写在前面事情的起因是我昨天在测试Linux安装Python3的shell脚本时,需要卸载Python3重新安装一遍。但是通过如下命令卸载python3时,少写了个3,不小心将系统自带的python2也...
- 如何使用Python将多个excel文件数据快速汇总?
-
在数据分析和处理的过程中,Excel文件是我们经常会遇到的数据格式之一。本文将通过一个具体的示例,展示如何使用Python和Pandas库来读取、合并和处理多个Excel文件的数据,并最终生成一个包含...
- 【第三弹】用Python实现Excel的vlookup功能
-
今天继续用pandas实现Excel的vlookup功能,假设我们的2个表长成这样:我们希望把Sheet2的部门匹在Sheet1的最后一列。话不多说,先上代码:importpandasaspd...
- python中pandas读取excel单列及连续多列数据
-
案例:想获取test.xls中C列、H列以后(当H列后列数未知时)的所有数据。importpandasaspdfile_name=r'D:\test.xls'#表格绝对...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python自定义函数 (53)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python人脸识别 (54)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)