【C语言】关于斐波那契数的求法
2016-07-26 15:21
183 查看
斐波那契数,亦称之为斐波那契数列(意大利语: Successione di Fibonacci),又称黄金分割数列、费波那西数列、费波拿契数、费氏数列,指的是这样一个数列:1、1、2、3、5、8、13、21、……在数学上,斐波那契数列以如下被以递归的方法定义:F0=0,F1=1,Fn=Fn-1+Fn-2(n>=2,n∈N*)。用文字来说,就是斐波那契数列列由 0 和 1 开始,之后的斐波那契数列系数就由之前的两数相加。
思路:第一种是利用递归。
第二种是利用迭代。
两种算法相比,递归的代码量小而且容易看懂,但是存在的弊端是当n较大时,递归所用的时间远远大于迭代运行出来所用的时间,而且它的冗余计算的数量也增长的非常快。比如在计算fib(10)时,fib(3)被计算了21次。当你在计算ib(30)时,fib(3)被计算了317 811次。所以在使用递归时就要考虑到,递归带来的好处是否抵得上它的代价。
思路:第一种是利用递归。
int fib(int n) //求第n个斐波那契数 { if(n<2) return n; else return fib(n-1)+fib(n-2); }
第二种是利用迭代。
int fib(int n) { if(n<2) return n; else { int i=0; int f0=0; int f1=1; int f2=0; for(i=2;i<=n;i++) { f2=f1+f0; f0=f1; f1=f2; } return f2; } }
两种算法相比,递归的代码量小而且容易看懂,但是存在的弊端是当n较大时,递归所用的时间远远大于迭代运行出来所用的时间,而且它的冗余计算的数量也增长的非常快。比如在计算fib(10)时,fib(3)被计算了21次。当你在计算ib(30)时,fib(3)被计算了317 811次。所以在使用递归时就要考虑到,递归带来的好处是否抵得上它的代价。
相关文章推荐
- c++map的用法
- C语言范例学习03-上
- C++ string使用for改变为何必须使用引用
- 数据的压缩存储与解压缩算法实现(C语言)
- 数据的压缩存储与解压缩算法实现(C语言)
- 数据的压缩存储与解压缩算法实现(C语言)
- C++虚函数表分析
- C/C++中的预编译指令
- C++指针详解(复习一下)
- codeforces 495B - Modular Equations
- 编译预处理
- codeforces - 495A Digital Counter
- java socket解析和发送二进制报文工具(附java和C++转化问题)
- c++ primer学习(三)表达式
- SIFT算法C语言逐步实现详解(上)
- 371. Sum of Two Integers
- c++ 子程序声明
- C语言单链表实现11个功能完全详解
- C++线程 消息队列
- C++关于模板