我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何用php实现斐波那契数列

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何用php实现斐波那契数列

这篇文章主要介绍了如何用php实现斐波那契数列的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何用php实现斐波那契数列文章都会有所收获,下面我们一起来看看吧。

实现方法:1、用数组来求,语法“for($i=0;$i<$n;$i++){if($i==0||$i==1){$arr[$i]=1;}else{$arr[$i]=$arr[$i-1]+$arr[$i-2];}echo $arr[$i];}”;2、用递归,语法“f($n){if($n==1||$n==2){return 1;}return f($n-1)+f($n-2);}}”。

斐波那契数是什么

斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:

1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597 2584 4181 6765.......

即:前两个值都为1,从第三位开始,每一位都是当前位前两位的和

如何用php实现斐波那契数列

在数学上,斐波那契数列以如下被以递推的方法定义:

F(1)=1,F(2)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 3,n ∈ N*)

  • F:指当前这个数列

  • n:指数列的下标

好了,了解了斐波那契数列,下面我们来了解一下使用PHP实现的方法。

方法1:利用数组

观察上面给出的数列,结合数组知识,可以分析出:

  • 数组下标为0或1时,元素的值为1

  • 数组下标为2时,元素是a[0]+a[1];

  • 数组下标为3时,元素是a[1]+a[2];

  • .....

  • 数组下标为n时,元素是a[n-2]+a[n-1];

可以得出:

  • a[0]=1

  • a[1]=2

  • a[n]=a[n-2]+a[n-1]   (n>2)

代码实现:

<?phpheader("Content-type:text/html;charset=utf-8");function test($num){    $arr=[];    for($i=0;$i<$num;$i++)    {        if($i==0 || $i==1){            $arr[$i]=1;        }else{            $arr[$i]=$arr[$i-1]+$arr[$i-2];        }echo $arr[$i]." ";    }}echo "斐波那契数列前10位:";test(10);echo "<br>斐波那契数列前11位:";test(11);echo "<br>斐波那契数列前12位:";test(12);?>

输出:

如何用php实现斐波那契数列

了解了如何利用数组来求斐波那契数列,下面我们来看看利用递归来求斐波那契数列。

方法2:使用递归

<?phpheader("Content-type:text/html;charset=utf-8");function fbnq($n) {if ($n <= 0) {return 0;}if ($n == 1 || $n == 2) {return 1;}return fbnq($n - 1) + fbnq($n - 2);}echo "斐波那契数列第10位:" . fbnq(10);echo "<br>斐波那契数列第11位:" . fbnq(11);echo "<br>斐波那契数列第12位:" . fbnq(12);?>

输出:

如何用php实现斐波那契数列

递归法也实现出来了,是不是很简单!

递归算法可以将一个负责的问题使用较短的代码将问题解决出来,但是运行的效率比较低。

关于“如何用php实现斐波那契数列”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“如何用php实现斐波那契数列”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何用php实现斐波那契数列

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何用php实现斐波那契数列

这篇文章主要介绍了如何用php实现斐波那契数列的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何用php实现斐波那契数列文章都会有所收获,下面我们一起来看看吧。实现方法:1、用数组来求,语法“for($i=0;
2023-07-05

怎么用php实现斐波那契数列

实现方法:1、用数组来求,语法“for($i=0;$i<$n;$i++){if($i==0||$i==1){$arr[$i]=1;}else{$arr[$i]=$arr[$i-1]+$arr[$i-2];}echo $arr[$i];}”;2、用递归,语法“f($n){if($n==1||$n==2){return 1;}return f($n-1)+f($n-2);}}”。
2023-05-14

python3斐波那契数列的实现

def fib(num): a,b=1,1 while a
2023-01-31

python实现斐波那契数列

斐波那契数列的发明者是意大利数学家昂纳多.斐波那契(Leonardo Fibonacci)。斐波那契数列又被称为黄金分割数列,或兔子数列。它指的是这样一个数列:0 1 1 2 3 5 8 13 21 34 ....在数学上,斐波那契数列以递
2023-01-31

C语言如何实现斐波那契数列

这篇文章主要介绍了C语言如何实现斐波那契数列的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言如何实现斐波那契数列文章都会有所收获,下面我们一起来看看吧。C语言数据结构递归之斐波那契数列首先,关于递归深度,递
2023-06-17

怎么使用python实现斐波那契数列

这篇文章主要介绍“怎么使用python实现斐波那契数列”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用python实现斐波那契数列”文章能帮助大家解决问题。斐波那契数列(Fibonacci s
2023-06-27

Python怎么实现斐波那契数列

这篇文章主要介绍“Python怎么实现斐波那契数列”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python怎么实现斐波那契数列”文章能帮助大家解决问题。1、递归方法输出斐波那契数列第n个元素的值2
2023-06-28

java如何实现斐波那契算法

以下是使用Java实现斐波那契算法的代码示例:public class Fibonacci {public static int fibonacci(int n) {if (n 这个程序使用递归的方式实现了斐波那契算法。在主函数中,我们
2023-10-23

Python/R语言如何分别实现斐波那契数列

这篇文章主要为大家展示了“Python/R语言如何分别实现斐波那契数列”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python/R语言如何分别实现斐波那契数列”这篇文章吧。1、年龄计算有 5
2023-06-29

使用javascript怎么实现一个斐波那契数列

使用javascript怎么实现一个斐波那契数列?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。JavaScript实现斐波那契数列斐波那契数列,又称黄金分割数列,指的是这样
2023-06-14

Python中怎么实现一个斐波那契数列

本篇文章给大家分享的是有关Python中怎么实现一个斐波那契数列,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、递归方法输出斐波那契数列第n个元素的值2、用迭代器和生成器获取
2023-06-02

python递归函数斐波那契数列怎么实现

斐波那契数列是一个数列,其中每个数字是前两个数字的和,即F(n) = F(n-1) + F(n-2)。递归函数可以用来实现斐波那契数列。下面是一个使用递归函数实现斐波那契数列的例子:```pythondef fibonacci(n):if
2023-09-26

python实现斐波那契数列的方法示例

介绍 斐波那契数列,又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、……在数学上,斐波纳契数列以如下递归的方法定义: F(0)=0,F(1)=1,F(n)=F(n-1)+F(n-2)(n≥2,n∈N*) 。1.
2022-06-04

Go语言怎么实现斐波那契数列

这篇文章主要介绍“ Go语言怎么实现斐波那契数列”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ Go语言怎么实现斐波那契数列”文章能帮助大家解决问题。斐波那契数列以下实例通过 Go 语言的递归函数实
2023-06-19

用Python实现斐波那契(Fibonacci)函数

Fibonacci斐波那契数列,很简单,就是一个递归嘛,学任何编程语言可能都会做一下这个。 最近在玩Python,在粗略的看了一下Learning Python和Core Python之后,偶然发现网上有个帖子Python程序员的进化写的很
2022-06-04

java中斐波那契数列的简单实现方法

斐波那契数列指的是:数列的后项等于前两项的和,代码中我们用a[i]=a[i-1]+a[i-2]实现。典型兔子生小兔问题古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对,假设每对小兔子都不死,编程实现求每个月兔子对数
java中斐波那契数列的简单实现方法
2021-03-23

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录