【问题描述】:使用递归和非递归的方法分别实现求第n个斐波那契数,那么什么是斐波那契数。斐波那契数列指的是这样一个数列:1、1、2、3、5、8、13、21,后面的每一个数是前面两个数的和。
【解决方法】:
方法一:递归实现
思路:
参考代码:
#include<stdio.h>
#include<windows.h>
int fabonacci(int n)
{
if (n <= 2)
return 1;
else
return fabonacci(n - 1) + fabonacci(n - 2);
}
int main()
{
int n = 3;
printf("请输入要求第几个数:");
scanf("%d", &n);
int ret = fabonacci(n);
printf("ret=%d\n", ret);
system("pause");
return 0;
}
方法二:迭代(非递归)
当我们用递归实现了求第n个斐波那契数时,我们是否考虑到当n很大的时候这段代码的执行效率很低。
例如,在递归计算Fibonacci(10)时,Fibonacci(3)的值被重复计算了21次;在递归计算Fibonacci(30)时,Fibonacci(3)的值被重复计算了317811次!这个额外的花销是很大的,所以我们求一个很大的数时,应当考虑用迭代的方法。
参考代码:
int fabonacci(int n)
{
int a = 1;//第一个数
int b = 1;//第二个数
int c = 1;//n<=2时,第三个数为1
while (n > 2)
{
c = a + b;
a = b;
b = c;
n--;
}
return c;
}