首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >_斐波那契数列和斐波那契数

_斐波那契数列和斐波那契数

原创
作者头像
会洗碗的CV工程师
发布于 2023-11-24 14:46:34
发布于 2023-11-24 14:46:34
32500
代码可运行
举报
文章被收录于专栏:LongJava学习资料LongJava学习资料
运行总次数:0
代码可运行

一、什么是斐波那契数列

斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……在数学上,斐波那契数列以如下被以递推的方法定义:F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2)(≥ 2,∈ N*)

1202年,斐波那契在《计算之书(Liber Abaci)》中提出了斐波那契数列。根据该数列可折叠出斐波那契蜗牛;绘制出斐波那契螺旋线等。[3]此外,在现代物理、准晶体结构、化学等领域,该数列均有直接应用;为此,美国数学会从1963年起出版了一份名为《斐波那契数列季刊》的数学杂志,以专门刊载相关研究成果

斐波那契数列的定义者,是意大利数学家莱昂纳多·斐波那契(LeonardoFibonacci),生于公元1170年,卒于1250年,籍贯是比萨。他被人称作“比萨的莱昂纳多”。1202年,他撰写了《算盘全书》(Liber Abacci)一书。他是第一个研究了印度和阿拉伯数学理论的欧洲人。他的父亲被比萨的一家商业团体聘任为外交领事,派驻地点于阿尔及利亚地区,莱昂纳多因此得以在一个阿拉伯老师的指导下研究数学。他还曾在埃及叙利亚希腊、西西里和普罗旺斯等地研究数学。另外斐波那契还在计算机C语言程序题中应用广泛

二、求有m位的斐波那契数列

        好啦,此时我们已经知道原理了,那就很容易啦,我们可以使用集合对象ArrayList,泛型为BigInteger的集合对象来存放数列,由于斐波那契数列前两位都是1,所以我们可以把集合对象的前两位单独处理,剩下的就是一个for循环的事情啦。

        代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    //求前m位的斐波那契数列,并把他们存到ArrayList集合中
    public static ArrayList<BigInteger> fibBuffRec (int m) {
        ArrayList<BigInteger> fibRec = new ArrayList<>(m);
        fibRec.add(BigInteger.ONE);
        fibRec.add(BigInteger.ONE);
        for(int i = 3;i<=m;i++){
            fibRec.add(fibRec.get(i-3).add(fibRec.get(i-2)));
        }
        return fibRec;
    }

三、求第m位的斐波那契数

        那么,我为什么不先把求第m位斐波那契数放到第二个标题呢?其实这里我想说的是,如果m的值比较大的话,比如说m>40的话,如果是在比赛的话,就不建议使用以下方法,因为这样执行过程会比较慢,建议先用上面方法求出有m位的斐波那契数列,然后直接使用ArrayList.get(m),直接获得即可,这样算法的空间度虽然说比较大,但是速度很快。如果m<40的话,就可以直接用递归的方法求第m位斐波那契数。如果m>40的话,需要等待一下才可以出结果了,读者可以自行测验呢。

        代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    //求第m位斐波那契数列的值,如果m<3直接返回1
    public static BigInteger diGui_fibBuffRec(int m){
        if(m>=3){
            return diGui_fibBuffRec(m-1).add(diGui_fibBuffRec(m-2));
        }
        else
            return BigInteger.ONE;
    }

我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
斐波那契数列和斐波那契数
        斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……在数学上,斐波那契数列以如下被以递推的方法定义:F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)
会洗碗的CV工程师
2022/11/29
8920
斐波那契数列和斐波那契数
斐波那契数列之美
有这样一个数列:1、1、2、3、5、8、13、21、34……前两个元素为1,其他元素均为前两个元素和。在数学上以如下递归的方法定义: 这就是斐波那契数列的数学定义。那数学家是如何发现(或创造)
Peter Lu
2018/06/20
1.4K0
趣味算法-03-跟着作者读《趣味算法(第2版)》-算法之美
趣味算法-01-跟着作者读《趣味算法(第2版)》上 趣味算法-02-跟着作者读《趣味算法(第2版)》下 趣味算法-03-跟着作者读《趣味算法(第2版)》-算法之美 趣味算法-04-跟着作者读《趣味算法(第2版)》-贪心算法 本文是系列博客的第3篇,是听了陈老师的报告后的记录,主要包括如何学习算法。
IT从业者张某某
2022/11/12
4100
趣味算法-03-跟着作者读《趣味算法(第2版)》-算法之美
Python学习笔记1——斐波那契数列
这是一个高中同学问我的问题,本来是用C来写的,正好正在学Python,就用Python重写了一遍当作练习。 下面是题目要求: 一道很简单的题目,但有些细节还是要注意的,我第一次写的代码在细节上就不是很完美。 首先来看看什么是Fibonacci数列。 斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……
企鹅号小编
2018/01/23
1.3K0
Python学习笔记1——斐波那契数列
剑指Offer(六)--斐波那契数列
大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0,第1项是1)。n<=39
秦怀杂货店
2022/02/15
1870
剑指Offer(六)--斐波那契数列
【C语言】斐波那契数列细讲
可惜已不在
2024/10/17
1880
【C语言】斐波那契数列细讲
java生成斐波那契数列
在Java中,生成斐波那契数列的方法通常是使用循环或递归。下面分别介绍这两种方法。
堕落飞鸟
2023/03/31
4750
【Java实战】——手撕斐波那契数列
斐波那契数列(Fibonacci sequence),又称黄金分割数列 [1],因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称“兔子数列”,其数值为:0、1、1、2、3、5、8、13、21、34……在数学上,这一数列以如下递推的方法定义:F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)。
User_芊芊君子
2025/04/12
1860
【Java实战】——手撕斐波那契数列
斐波那契数列
斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、…… 如果设F(n)为该数列的第n项(n∈N*),那么这句话可以写成如下形式::F(n)=F(n-1)+F(n-2) 显然这是一个线性递推数列。 代码实现
呆呆
2021/10/06
4490
数据结构与算法-斐波那契数列
简介 斐波那契数列(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>=3,n∈N*)在现代物理、准晶体结构、化学等领域,斐波纳契数列都有直接的应用,为此,美国数学会从1963年起出版了以《斐波纳契
cwl_java
2019/10/26
6290
数学之美|斐波那契数列与黄金分割
趣味算法(第二版)读书笔记: day1: 序章|学习的方法和目标. day2:算法之美|打开算法之门与算法复杂性 day3.算法之美|指数型函数对算法的影响实际应用 day4.数学之美|斐波那契数列与黄金分割 day5.算法实践|贪心算法基础 day6.算法实践|最优装载 day7.算法实践|背包问题
破晓之翼
2022/11/18
6760
数学之美|斐波那契数列与黄金分割
python中使用递归实现斐波那契数列
斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……在数学上,斐波那契数列以如下被以递推的方法定义:F(0)=0,F(1)=1, F(n)=F(n – 1)+F(n – 2)(n ≥ 2,n ∈ N)在现代物理、准晶体结构、化学等领域,斐波纳契数列都有直接的应用,为此,美国数学会从 1963 年起出版了以《斐波纳契数列季刊》为名的一份数学杂志,用于专门刊载这方面的研究成果。*
全栈程序员站长
2022/07/04
8660
python中使用递归实现斐波那契数列
C++实现斐波那契数列
斐波那契数列(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*)
week
2018/08/24
3480
斐波那契数列 -- C/C++ 实现
斐波那契数列有一个规律,斐波那契数列的前一项加上它的后一项等于下一项。因此,使用递推的算法可以很容易实现,即F(n)=F(n - 1)+F(n - 2)。
Skykguj
2022/09/09
6540
斐波那契数列(用c语言探索黄金分割之美)
摘要:本文将介绍斐波那契数列的概念、性质及应用,并通过C语言代码实例演示如何实现斐波那契数列。 一、斐波那契数列的定义与性质 斐波那契数列(Fibonacci sequence)又称黄金分割数列,由数学家列昂纳多·斐波那契(Leonardo da Fibonacci)在《计算之书》中以兔子繁殖为例子引入。斐波那契数列的定义如下: F(0) = 0 F(1) = 1 F(n) = F(n-1) + F(n-2) (n > 2,n ∈ N) 斐波那契数列的前几项为:0,1,1,2,3,5,8,13,21,34,55,89,144…… 二、斐波那契数列的性质 1. 递推性:斐波那契数列满足递推关系式,即每个数字都是前两个数字之和。 2. 黄金分割比例:随着斐波那契数值的增加,前一项与后一项的比值越来越接近黄金分割比例0.6180339887(约等于1 / 1.6180339887)。 3. 斐波那契数列与黄金分割在自然界、艺术、建筑等领域有广泛的应用。 三、代码示例 下面使用C语言实现斐波那契数列:
GG Bond1
2024/06/14
1780
Python之斐波那契数列的实现
斐波那契数列指的是这样一个数列:1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597 2584 4181 6765 ……这个数列从第3项开始,每一项都等于前两项之和。
芯动大师
2022/11/15
8070
Python之斐波那契数列的实现
python实现斐波那契数列
斐波那契数列的发明者是意大利数学家昂纳多.斐波那契(Leonardo Fibonacci)。斐波那契数列又被称为黄金分割数列,或兔子数列。它指的是这样一个数列:0 1 1 2 3 5 8 13 21 34 ....在数学上,斐波那契数列以递归的方法定义:F(0)=0,F(1)=1,F(n)=F(n-1)+F(n-2(N>=2,n属于N*)。简单的说明斐波那切数列的规律为:第1个数为0,第2个数为1,之后每个数值都是前两位的和。
py3study
2020/01/14
5650
斐波那契数列的四种实现
孔乙己自己知道不能和他们谈天,便只好向 Intern 说话。有一回对我说道,“你写过代码么?”我略略点一点头。他说,“写过代码,……我便考你一考。斐波那契数列的输出,怎样实现?”我想,讨饭一样的人,也配考我么?便回过脸去,不再理会。孔乙己等了许久,很恳切的说道,“不能写罢?……我教给你,记着!这些代码应该记着。将来做 Leader 的时候,开发项目要用。”我暗想我和 Leader 的等级还很远呢,而且我们 Leader 也从不在项目里写斐波那契;又好笑,又不耐烦,懒懒的答他道,“谁要你教,不是递归么?”孔乙己显出极高兴的样子,将两个指头的长指甲敲着键盘,点头说,“对呀对呀!……斐波那契有四样写法,你知道么?”我愈不耐烦了,努着嘴走远。孔乙己刚在命令行打开 Vim,想在里面写代码,见我毫不热心,便又叹一口气,显出极惋惜的样子。
Crossin先生
2020/02/21
7500
Python|斐波那契数列
斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……
算法与编程之美
2020/04/20
8620
Python|斐波那契数列
剑指Offer的学习笔记(C#篇)-- 斐波那契数列
        斐波那契数列概念:斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”(来自百度百科)。具体可由以下公式表示:
WeiMLing
2022/05/06
4640
剑指Offer的学习笔记(C#篇)-- 斐波那契数列
相关推荐
斐波那契数列和斐波那契数
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验