今天看到群友发的一个问题:写一个小程序打印第n个斐波那契数。
自己试了下,搞了好久。。。基础要加强了。
进入正题,什么是斐波那契数列就不说了,拿到这个题目,直接写出如下代码:
public static long findFibonacci(int n){
if(n <= 2){
return 1;
}else{
return findFibonacci(n - 1) + findFibonacci(n - 2);
}
}
运行一下,输入n分别为:1,2,3,4,5 输出分别为1,1,2,3,5。貌似是正确的,看看有什么问题,如果我们输入n为45。
public static void main(String[] args) {
long s = System.currentTimeMillis();
System.out.println(findFibonacci(45));
long e = System.currentTimeMillis();
System.out.println("程序运行耗时["+(e-s)+"]毫秒!");
}
输出如下:
1134903170
程序运行耗时[4875]毫秒!
如果输入100的话,就一直在运行。。。。。
上面程序的问题在于,计算第n个f数时需要计算第n-1和第n-2个f数,但是计算第n+1个f数的时候又要重新计算第n个f数,如此反复,要处理的子问题的数量爆炸式增长。我们加点输出看看。
public static long findFibonacci(int n){
if(n <= 2){
System.out.println("计算第["+n+"]个斐波那契数[1]");
return 1;
}else{
long fb = findFibonacci(n - 1) + findFibonacci(n - 2);
System.out.println("计算第["+n+"]个斐波那契数["+fb+"]");
return fb;
}
}
n输入为5,输出如下:
计算第[2]个斐波那契数[1]
计算第[1]个斐波那契数[1]
计算第[3]个斐波那契数[2]
计算第[2]个斐波那契数[1]
计算第[4]个斐波那契数[3]
计算第[2]个斐波那契数[1]
计算第[1]个斐波那契数[1]
计算第[3]个斐波那契数[2]
计算第[5]个斐波那契数[5]
5
程序运行耗时[0]毫秒!
如何解决这个问题呢,如果我们能重复利用子问题的结果,而不是每次去重新求解子问题,这样程序就会快很多,这种处理问题的方式也叫做动态规划。
针对这个问题,假设我们要求第n个斐波那契数,我们可以建立一个长度为n(为n-1就可以,但为了编码方便)的数组用来保存子问题结果,代码如下:
private static long findFibonacci1(int n, long[] c){
int index = n - 1;
if(c[index] != 0){
return c[index];
}
if(n <= 2){
c[index] = 1;
}else{
c[index] = findFibonacci1(n - 1,c) + findFibonacci1(n - 2,c);
}
return c[index];
}
public static long findFibonacci1(int n){
long c[] = new long[n];
return findFibonacci1(n,c);
}
这次输入45,看看结果:
1134903170
程序运行耗时[0]毫秒!
这次没问题了。再想想,其实每次求第n个f数只需要重用第n-1和第n-2个f数就可以了,而且依据代码,问题的解决是自底向上的,所以每次保存2个就够了,我们先搞点日志看看。
private static long findFibonacci1(int n, long[] c){
int index = n - 1;
if(c[index] != 0){
System.out.println("从数组下标["+index+"]中获取数据["+c[index]+"]");
return c[index];
}
if(n <= 2){
c[index] = 1;
}else{
c[index] = findFibonacci1(n - 1,c) + findFibonacci1(n - 2,c);
}
return c[index];
}
输入7,看输出:
从数组下标[1]中获取数据[1]
从数组下标[2]中获取数据[2]
从数组下标[3]中获取数据[3]
从数组下标[4]中获取数据[5]
13
程序运行耗时[0]毫秒!
可以看到,会从小到大从数组中取数据。继续看看能不能每次只保存2个子问题结果。看代码:
private static long findFibonacci2(int n, long[] c){
int index = n % 2;
if(c[index] != 0){
System.out.println("从数组下标["+index+"]中获取数据["+c[index]+"]");
return c[index];
}
if(n <= 2){
c[index] = 1;
}else{
c[index] = findFibonacci2(n - 1,c) + findFibonacci2(n - 2,c);
}
return c[index];
}
public static long findFibonacci2(int n){
long c[] = new long[2];
return findFibonacci2(n,c);
}
输出8,看看输出:
从数组下标[0]中获取数据[1]
从数组下标[1]中获取数据[2]
从数组下标[0]中获取数据[3]
从数组下标[1]中获取数据[5]
从数组下标[0]中获取数据[8]
21
程序运行耗时[0]毫秒!
嗯,果然可以。去掉打印语句,输出1000,看看输出:
817770325994397771
程序运行耗时[0]毫秒!
ok,嘎嘎。不过这道题直接用循环貌似更简单。。。。
再来个更短的(无聊)
private static long f(int n, long[] a){
return a[n & 1] == 0 ? (n <= 2 ? (a[n & 1] = 1)
:(a[n & 1] = f(n - 1, a) + f(n - 2, a))) : a[n & 1];
}
public static long findNthFibonacci(int n){
return f(n, new long[2]);
}
分享到:
相关推荐
这个代码是用来求第N个斐波那契数,仅供交流,不喜勿喷!
double Fibonacci(int n) { double f1=0,f2=1,f; int i; for(i=2; i<=n; i++) { f=f1+f2; f1=f2; f2=f; } return f; } int main(void) { int n; double f; printf("请输入n="); scanf("%d",&n); f=Fibonacci(n); ...
函数 求第n个斐波那契数
可以求1~100内的fibonacci数,,超出范围数据段要重新定义
输出前n个斐波那契数 c++
递归方法 def fibonacci(n): if n <= 1: return n else: return fibonacci(n-1) + fibonacci(n-2) n = int(input("请输入要计算的斐波那契数列的项数:")) print("斐波那契数列的第", n, "项为:", fibonacci(n)) 2...
多种算法计算Fibonacci数,比较效率,写得不好,还望指正
【问题描述】编写函数f,功能是用递归的方法求斐波那契数列的第n项,函数原型为 int f(int n),在主函数中输入一个正整数n,调用函数f求出斐波那契数列的第n项,并在主函数中输出。 斐波那契数列:1,1,2,3,5,8,13,...
用递推算法 迭代算法 公式法计算求第N个Fibonacci数,计算机能算出最大Fibonacci时N的值,计算1分钟内能计算几个Fibonacci,用公式法计算Fibonacci,当出现错误时,N为多少。
使用函数输出fibonacci数 你可以使用Python来创建一个函数,输出斐波那契数列。以下是一个简单的例子: ...这个实现利用了一个列表来存储斐波那契数列,然后返回列表的最后一个元素,即第n个斐波那契数。
C语言程序设计-用函数求fibonacci数列前n项的和;说明:fibonacci数列为数列的第一项值为1,第二项值也为1,从第三项开始,每一项均为其前面相邻两项的和;例如:当n=28时,运行结果:832039.c
java代码实现斐波那契数列 类似1 1 2 3 5 8 输出第n个数 java开发工程师 笔试一般经常考到
在不同的编程语言中查找第 N 个斐波那契数 关于 斐波那契数列是由简单的线性递推关系定义的整数序列。 该序列出现在数学和其他科学的许多环境中。 特别是,许多天然存在的生物体的形状受斐波那契数列及其近亲黄金...
根据给定的n值,计算Fibonacci数 程序输出FIB(n)
斐波那契程序取一个整数,并打印出斐波那契数列的该项。 在程序中创建斐波那契数列。 只存储最后两个值。
斐波那契数列c 以下是一个用C++编写的斐波那契数列程序: ```cpp #include // 函数定义,返回第 n 个斐波那契数 ...然后在`main`函数中获取用户输入的位置n,并调用`fibonacci`函数来计算并输出第n个斐波那契数。
Fibonacci斐波那契数列,很简单,就是一...要求很简单,输入n,输出第n个Fibonacci数,n为正整数 下面是这九种不同的风格: 1)第一次写程序的Python程序员: def fib(n): return nth fibonacci number 说明: 第
在数学上,第n个斐波那契数有一个公式。 我已经看到该实现称为O(1)。 但是,这依赖于浮点数并执行诸如浮点取幂之类的操作,因此我不确定它的速度或精度或O(1)是多少。 如果没有溢出,此程序将给出确切的答案-...
主要给大家介绍了关于使用python求斐波那契数列中第n个数的值的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用python具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
给定一个整数 n,返回第 n 个斐波那契数。