一分钟让你轻松拿捏 求解斐波那契数列!

news/2024/12/5 12:00:16/

文章目录

  • 斐波那契数列的概念
  • 递归求解第N个斐波那契数
  • 迭代求解第N个斐波那契数
  • 递归法和迭代法的比较

斐波那契数列的概念

斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(LeonardodaFibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列: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年起出版了以《斐波纳契数列季刊》为名的一份数学杂志,用于专门刊载这方面的研究成果。

递归求解第N个斐波那契数

通过对斐波那契数的了解,我们很容易写出下面这个通项公式:

在这里插入图片描述
写出通项公式后用递归方法来实现就比较简单了:

long long Fibonacci(int n)
{if (n == 0 || n == 1)return n;elsereturn Fibonacci(n - 1) + Fibonacci(n - 2);
}//递归

迭代求解第N个斐波那契数

迭代也就是我们通常所说的循环,即用循环的方法来求第n个斐波那契数:

long long Fibonacci(int n)
{if (n == 0)return 0;else if (n == 1)return 1;long long a = 0;long long b = 1;long long c = 1;while (n - 2){a = b;b = c;c = a + b;n--;}return c;
}//迭代法

递归法和迭代法的比较

看到递归法与迭代法的实现之后,那么你认为哪一种方法比较好呢?

如果只看表面上的代码量,你可能以为递归法的实现更为简单,但在运行时,当你要求第50个斐波那契数的时候,递归法迟迟给不出运行结果,而迭代法不要说是求第50个斐波那契数,就算是求第100个,第1000个,第10000个斐波那契数,都是秒出结果。那这是什么原因呢?

其实,在递归法中,我们要求第50个斐波那契数,就要先求第49个和第48个斐波那契数,而要求第49个斐波那契数,又要先求第48个和第47个斐波那契数,要求第48个斐波那契数,就要先求第47个和第46个斐波那契数…

在这里插入图片描述

在图中我们可以看到,递归法中做了很多“无用功”,即对同一斐波那契数进行了多次求解。这里可以用一个代码来说明:

#include <stdio.h>
int count = 0;
long long Fibonacci(int n)
{if (n == 0)count++;if (n == 0 || n == 1)return n;elsereturn Fibonacci(n - 1) + Fibonacci(n - 2);
}//递归
int main()
{Fibonacci(20);printf("%d\n", count);return 0;
}

这里我们要求第20个斐波那契数,我们用一个变量count来记录这个过程中Fibonacci(0)被执行的次数,结果惊人的发现:
在求第20个斐波那契数的过程中,我们仅仅对Fibonacci(0)就执行了4181次,更不用说还有Fibonacci(1)、Fibonacci(2)、Fibonacci(3)等等,而且这只是求第20个斐波那契数的过程就这样“艰难”了,更不用说求第50个斐波那契数的过程了。所以,用递归法计算第50个斐波那契数时出现迟迟没有结果的现象也是有原因的,因为计算机确实在努力计算了,只是做了太多重复计算。

而迭代法就不一样了,无论你求第几个斐波那契数,该函数只会调用一次,最主要的是:迭代法不会对同一个斐波那契数进行重复计算。

总结:

1.递归法虽然写法简单,但求解斐波那契数时会对同一斐波那契数进行多次计算,做了太多“无用功”。
2.迭代法虽然代码量相比递归法要多,但它对同一斐波那契数只会计算一次,避免了做“无用功”。


http://www.ppmy.cn/news/465444.html

相关文章

Python模拟微信发红包

Python模拟微信发红包 from decimal import Decimal # 提供了随机方法 import random print($$$$$$weichat模拟微信抢红包$$$$) total input(请输入要装入红包的总金额&#xff08;元&#xff09;&#xff1a;) num input(请输入红包的个数&#xff08;个&#xff09;&#xf…

iPhone发红包还可以这样

春节少不了发红包给亲朋好友拜年&#xff0c;你知道吗&#xff0c;除了使用微信和支付宝之外&#xff0c;你还能在iPhone上使用iMessage信息功能发送红包。 使用条件&#xff1a; 您和好友都需要使用iPhone手机&#xff08;此功能支持iOS11或更新系统&#xff09;&#xff0c;需…

写了一个微信发红包的代码

import java.io.Serializable; import java.math.BigDecimal; import java.util.ArrayList; import java.util.List; import java.util.Random;public class WeChatClub {public static void main(String[] args) {int sendMoney 10000; // 100元int size 6; // 红包个数Pers…

python实现微信发红包

微信发红包规则 第一种&#xff0c;单独给某个好友发红包&#xff1a;0 < 金额 < 200&#xff0c;金额支持两位小数 第二种&#xff0c;群红包&#xff0c;有以下三种类型&#xff1a; 1&#xff09; 拼手气红包&#xff1a;1 < 红包个数 < 当前群聊人数&#xff0…

Python 实现发红包

问题描述 使用 python 实现类似微信发红包的功能&#xff0c;尽量保持每个人收获的红包平均&#xff0c;要求输入总金额 money&#xff08;元-float&#xff09;及红包个数 num&#xff08;个-int&#xff09;&#xff0c;且每人最小获得的红包额度不能小于0.01元&#xff08;…

利用Python制作一个发红包的小游戏

本系统的内容是综合应用python程序设计的知识&#xff0c;实际并实现了一款简单发红包的小游戏&#xff0c;具体功能如下&#xff1a; &#xff08;1&#xff09;拼手气红包&#xff1a;随机金额 &#xff08;2&#xff09;普通红包&#xff1a;能够通过输入的红包人数与红包…

微信公众号怎么发红包?

#微信公众号怎么发红包# 利用微信公众号给粉丝派发红包是日常运营中不可或缺的一种营销方式&#xff0c;活动中植入了微信红包元素&#xff0c;可以大大吸引用户的关注&#xff0c;不管是给公众号引流还是提升粉丝活跃度都是非常有效的&#xff0c;但是还有不少公众号运营者不…

python模拟简单发红包

import random def redEnv(k,rest):mround(round(random.random()/100.01,2)*rest,2)return m totalfloat(input(请输入红包金额&#xff1a;)) numint(input(请输入红包个数:)) remaintotal for i in range(num-1):moneyredEnv(i,remain)remain-moneyprint(红包{0:d}:{1:.2f}.…