费波那契数列的定义:

费波那契数列意大利语:Successione
di Fibonacci),又译费波拿契数斐波那契数列斐波那契数列黄金切割数列

数学上,费波那契数列是以递归的方法来定义:

  • (n≧2)

用文字来说,就是费波那契数列由0和1開始。之后的费波那契系数就由之前的两数相加。

首几个费波那契系数是:01123581321345589144233……

特别指出0不是第一项。而是第零项。

以下是费波那契数列的几种常见编程实现:

1、常规实现:

  1. int Fibonacci(int n)
  2. {
  3. int a = 1, b = 1;
  4. if(n < 0)
  5. {
  6. printf("The fibonacci number exists only with nonnegative index.\n");
  7. return -1;
  8. }
  9. else if (n == 0)
  10. return 0;
  11. else if(n==1 || n==2)
  12. return 1;
  13. else
  14. {
  15. for(int i=3; i<=n; i++)
  16. {
  17. int tmp = b;
  18. b = a + b;
  19. a = tmp;
  20. }
  21. return b;
  22. }
  23. }

2、递归实现:

  1. int Fibonacci(int n)
  2. {
  3. if(n < 0)
  4. printf("The fibonacci number exists only with nonnegative index.\n");
  5. else
  6. {
  7. if(n == 0)
  8. return 0;
  9. else if(n == 1)
  10. return 1;
  11. else
  12. return Fibonacci(n - 1) + Fibonacci(n - 2);
  13. }
  14. }

3、迭代实现:

  1. int Fibonacci_iter(int a, int b, int count)
  2. {
  3. if(count < 0)
  4. printf("The fibonacci number exists only with nonnegative index.\n");
  5. else if(count == 0)
  6. return b;
  7. else
  8. return Fibonacci_iter(a + b, a, count - 1);
  9. }
  10.  
  11. int Fibonacci(int n)
  12. {
  13. return Fibonacci_iter(1, 0, n);
  14. }

4、元编程实现:

  1. #include<iostream>
  2.  
  3. using namespace std;
  4.  
  5. int Result;
  6.  
  7. //主模板
  8. template<int N> //模板
  9. class Fibonacci
  10. {
  11. public:
  12. enum{Result = Fibonacci<N-1>::Result + Fibonacci<N-2>::Result }; //枚举。带有隐含计算
  13. };
  14.  
  15. //全然特化模板
  16. template<>
  17. class Fibonacci<1> //带常參数1的构造函数
  18. {
  19. public:
  20. enum { Result = 1 }; //给枚举赋初值1
  21. };
  22.  
  23. //全然特化模板
  24. template<>
  25. class Fibonacci<0> //带參数0的模板
  26. {
  27. public:
  28. enum { Result = 0 }; //给枚举赋初值0
  29. };
  30.  
  31. int main()
  32. {
  33. std::cout << "第20项的Fibonacci数是:" << Fibonacci<20>::Result << std::endl; //隐含计算
  34. system("pause");
  35. return 1;
  36. }

总结:

递归英语:Recursion)。又译为递回,在数学计算机科学中。是指在函数的定义中使用函数自身的方法。

迭代,数学中的迭代能够指函数迭代的过程。即重复地运用同一函数计算,前一次迭代得到的结果被用于作为下一次迭代的输入。

使用递归要注意的有两点:

1)递归就是在过程或函数里面调用自身;

2)在使用递归时,必须有一个明白的递归结束条件,称为递归出口.

递归分为两个阶段:

1)递推:把复杂的问题的求解推到比原问题简单一些的问题的求解;

2)回归:当获得最简单的情况后,逐步返回,依次得到复杂的解.

迭代:利用变量的原值推算出变量的一个新值.假设递归是自己调用自己的话,迭代就是A不停的调用B.

递归中一定有迭代,可是迭代中不一定有递归,大部分能够相互转换.能用迭代的不用递归,递归调用函数,浪费空间,而且递归太深easy造成堆栈的溢出.

元编程(Metaprogramming)是指某类计算机程序的编写。这类计算机程序编写或者操纵其它程序(或者自身)作为它们的数据,或者在执行时完毕部分本应在编译时完毕的工作。非常多情况下比手工编写所有代码相比工作效率更高。编写元程序的语言称之为元语言。被操作的语言称之为目标语言。一门语言同一时候也是自身的元语言的能力称之为反射

參考文献:

费波那契数列:http://zh.wikipedia.org/wiki/%E6%96%90%E6%B3%A2%E9%82%A3%E5%A5%91%E6%95%B0%E5%88%97

迭代:http://zh.wikipedia.org/wiki/%E8%BF%AD%E4%BB%A3

递归:http://zh.wikipedia.org/wiki/%E9%80%92%E5%BD%92

递归与迭代的差别:http://blog.csdn.net/swliao/article/details/5337896

递归与迭代:http://blog.csdn.net/ljyf5593/article/details/5935795

关于fibonacci递归算法和迭代算法在C和Scheme下实现存在差距的疑惑:http://bbs.csdn.net/topics/190008464

Fibonacci series(斐波纳契数列)的几种常见实现方式的更多相关文章

  1. 10、end关键字和Fibonacci series: 斐波纳契数列

    # Fibonacci series: 斐波纳契数列 # 两个元素的总和确定了下一个数 a, b = 0, 1 #复合赋值表达式,a,b同时赋值0和1 while b < 10: print(b ...

  2. 012_Python3 斐波纳契数列 + end 关键字

    1.个斐波纳契数列. #!/usr/bin/python3   # Fibonacci series: 斐波纳契数列 # 两个元素的总和确定了下一个数 a, b = 0, 1 while b < ...

  3. Python3 编程第一步_斐波纳契数列_连续赋值

    # Fibonacci series: 斐波纳契数列 # 两个元素的总和确定了下一个数 a, b = 0, 1 while b < 10: print(b) a, b = b, a+b # 1 ...

  4. lintcode:Fibonacci 斐波纳契数列

    题目: 斐波纳契数列 查找斐波纳契数列中第 N 个数. 所谓的斐波纳契数列是指: 前2个数是 0 和 1 . 第 i 个数是第 i-1 个数和第i-2 个数的和. 斐波纳契数列的前10个数字是: 0, ...

  5. 使用一位数组解决 1 1 2 3 5 8 13 数列问题 斐波纳契数列 Fibonacci

    斐波纳契数列 Fibonacci 输出这个数列的前20个数是什么? 1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597 使用数组实现输出数列的前30 ...

  6. 用PHP迭代器来实现一个斐波纳契数列(转)

    斐波纳契数列通常做法是用递归实现,当然还有其它的方法.这里现学现卖,用PHP的迭代器来实现一个斐波纳契数列,几乎没有什么难度,只是把类里的next()方法重写了一次.注释已经写到代码中,也是相当好理解 ...

  7. 算法之路(三)----查找斐波纳契数列中第 N 个数

    算法题目 查找斐波纳契数列中第 N 个数. 所谓的斐波纳契数列是指: * 前2个数是 0 和 1 . * 第 i 个数是第 i-1 个数和第i-2 个数的和. 斐波纳契数列的前10个数字是: 0, 1 ...

  8. 用PHP迭代器来实现一个斐波纳契数列

    斐波纳契数列通常做法是用递归实现,当然还有其它的方法.这里现学现卖,用PHP的迭代器来实现一个斐波纳契数列,几乎没有什么难度,只是把类里的next()方法重写了一次.注释已经写到代码中,也是相当好理解 ...

  9. LintCode 斐波纳契数列

    查找斐波纳契数列中第 N 个数. 所谓的斐波纳契数列是指: 前2个数是 0 和 1 . 第 i 个数是第 i-1 个数和第i-2 个数的和. 斐波纳契数列的前10个数字是: 0, 1, 1, 2, 3 ...

随机推荐

  1. 一、ELKStack介绍与入门实践

    第1章 ELKStack 对于日志来说,最常见的需求就是收集.存储.查询.展示,开源社区正好有相对应的开源项目:logstash(收集).elasticsearch(存储+搜索).kibana(展示) ...

  2. Laravel 5系列教程二:路由,视图,控制器工作流程

    免费视频教程地址https://laravist.com/series/laravel-5-basic 上一篇教程我们走了那么长的路,终于把Laravel安装好了,这一篇教程我们就要进入Laravel ...

  3. 解决Spark集群无法停止

    执行stop-all.sh时,出现报错:no org.apache.spark.deploy.master.Master to stop,no org.apache.spark.deploy.work ...

  4. Kafka 简单实验一(安装Kafka)

    Apache Kafka - 安装步骤 步骤1 - Java安装 希望您现在已经在您的计算机上安装了Java,因此您只需使用以下命令进行验证. $ java -version 如果您的计算机上成功安装 ...

  5. Linq-语句之Select/Distinct和Count/Sum/Min/Max/Avg

    上一篇讲述了LINQ,顺便说了一下Where操作,这篇开始我们继续说LINQ to SQL语句,目的让大家从语句的角度了解LINQ,LINQ包括LINQ to Objects.LINQ to Data ...

  6. Struts + Spring + Hibernate 进阶开端(一)

    Long Long ago,就听说过SSH,起初还以为是一个东东,具体内容更是不详,总觉得高端大气上档次,经过学习之后才发现,不仅仅是高大上,更是低调奢华有内涵,经过一段时间的研究和学习SSH框架的基 ...

  7. ant-design 实现 添加页面

    1.逻辑代码 /** * 添加用户 */ import React,{PureComponent} from 'react' import {Card,Form,Input,Select,Button ...

  8. 利用Perlin nosie 完毕(PS 滤镜—— 分成云彩)

    %%%% Cloud %%%% 利用perlin noise生成云彩 clc; clear all; close all; addpath('E:\PhotoShop Algortihm\Image ...

  9. Oracle安装过程中的几点注意

    为追求统一,安装了oracle 11g step 4时需要改一下名称,利于记忆 数据库安装完之后需要取消SCOTT账户的锁定 完成后点击SQL Developer会出现——"应用程序开发&q ...

  10. Mac OS X中配置Apache后提示You don't have permission to access / on this server

    根据这篇博客http://www.cnblogs.com/snandy/archive/2012/11/13/2765381.html,在mac系统中,配置的apache,配置完成后,提示 You d ...