用python怎样实现斐波那契数列,及计算阶乘
Admin 2022-06-08 群英技术资讯 1198 次浏览
这篇文章将为大家详细讲解有关“用python怎样实现斐波那契数列,及计算阶乘”的知识,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
之前小编向大家介绍了三种求公约数的方法,其中有一个是辗转相除法,又称欧几里得算法。在求公约数的时候,一般分析会当成数阶,数论中的最常用的欧几里得算法就和斐波那契数列有关。斐波那契数列是什么呢?是如何实现的呢?阶乘又是怎么求的呢?别急,跟着小编的脚步来看看吧。
一、相关概念
阶乘:一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。
斐波那契数列(Fibonacci sequence),又称黄金分割数列。因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……在数学上,斐波纳契数列以如下被以递归的方法定义:F(1)=1,F(2)=1, F(n)=F(n-1)+F(n-2)(n>=2,n∈N*)。
二、求阶乘
循环解法
n = int(input('请输入想求的阶乘:'))
for i in range(1,n):
n*=i
print(n)
递归解法
def factorial(n): if n==1: return 1 else: return n*factorial(n-1) print(factorial(5))
三、求斐波那契数列
递归解法
def fib(n): lt = [] for i in range(n): if i == 0 or i == 1: lt.append(1) else: lt.append(lt[i - 2] + lt[i - 1]) return lt print(fib(9))
迭代解法
def fab(n):
n1 = 1
n2 = 1
n3 = 1 #给 n3 赋一个初值
if n < 1:
print('输入有误!')
return -1
while (n-2) > 0: #当n为3时,大于0,n3=n2+n1
n3 = n2 + n1
n1 = n2 #计算下一次迭代,将n1与n2依次后移,n2给现在的n1,之前的n3给n2,重复运算求和
n2 = n3
n -=1 #计算一次减少一次n,直到n为2时,跳出循环
return n3
result = fab(20)
if result != -1:
print('总共有%d对兔子!'% result)
小编觉得求阶乘时循环挺简洁易懂的,递归比较抽象。对于求斐波那契数列来说,但并不是递归就适用于所有程序,在计算数值较大的情况下,使用迭代会速度更快。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文总结了两种方法来导入opencv与numpy包,第一种是直接在Pycharm中导入两个包,第二种是在官网下载相关文件进行配置,感兴趣的小伙伴们可以参考一下
今天教大家怎么用pygame实现简单的金币旋转效果,文中有非常详细的代码示例,对正在学习python的小伙伴们很有帮助,需要的朋友可以参考下
Python的urllib库可以做什么?对于python爬虫应用urllib库起着重要作用,有一些朋友对于urllib库使用不是很了解,对此这篇就给大家来介绍一下urllib库的使用,文中的介绍很详细,感兴趣的朋友就跟随小编一起来学习一下吧。
这篇文章主要介绍了Python实战之实现康威生命游戏,文中有非常详细的代码示例,对正在学习python的小伙伴们有非常好的帮助,需要的朋友可以参考下
本文讲述如何使用 tkinter 的布局管理 (被称作 layout managers 或 geometry managers). tkinter 有三种布局管理方式:pack,grid,place。注意这三种布局管理在同一个 master window 里一定不可以混用! 布局管理有以下功能:
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008