斐波那契数列的实现算法

最近在看算法方面的书籍,看到了一个很古老的问题-斐波那契数列,这个题目在大学的时候肯定接触过,我们还在考试中考过,但是只是局限于当时课本上的内容,并没有仔细的考虑过这个题目的实现方法,今天就来小小的探究一下

最常见的实现算法就是递归,这个问题也是一个很基础的递归算法实现的例子;

求斐波那契数列第n个元素java代码来实现递归的方法如下:

public static long FibonacciDemo1(long n) {
        if (n <= 0) return 0;
        if (n == 1) return 1;

        return FibonacciDemo1(n - 1) + FibonacciDemo1(n - 2);
}

递归方法实现是看起来最简洁的,但是并不是最好的;因为要求第n个元素的数据,就要先求第n-1和第n-2,同理要分别求f(n-2)+f(n-3)和f(n-3)+f(n-4),会存在大量的冗余计算;
例如要求f(10)的值需要分别做的计算如下:
在n逐渐增大的同时,运算时间也在指数增加,时间复杂度为O(2^n)

为了解决这个问题,提高运算效率,可以修改为一下方法

public static long FibonacciDemo2(long n) {
        if (n <= 0) return 0;

        long element1 = 1;
        long element2 = 0;
        long result = 0;

        for (int i = 0; i < n; i++) {
            result = element1 + element2;
            element1 = element2;
            element2 = result;
        }

        return result;
}虽然不再采用递归方法,并且代码看起来也更加的臃肿,但是在n趋向于大时,运算效率要远远高于递归方法,时间复杂度为O(n)

面试中,可能面试官并没有要求使用递归来实现一些算法,而我们常用的方法可能会禁锢我们的思维,有时候往往越普通的方法,能起到不一样的作用;但是这还不是最终的解答

我们来讨论一个时间复杂度为O(logn)的算法解答方法

原文地址:https://www.cnblogs.com/spiders/p/9337478.html

时间: 2024-10-15 11:34:00

斐波那契数列的实现算法的相关文章

java程序员到底该不该了解一点算法(一个简单的递归计算斐波那契数列的案例说明算法对程序的重要性)

为什么说 “算法是程序的灵魂这句话一点也不为过”,请看下面这个简单的案例 1 package recursion; 2 3 import java.util.HashMap; 4 import java.util.Map; 5 6 import org.junit.Test; 7 8 /** 9 * @author: MengXianman 10 * @creationTime: 2017年11月27日 上午9:47:51 11 * @description: 斐波那契数列结合备忘录算法的简单使

几种复杂度的斐波那契数列的Java实现

一:斐波那契数列问题的起源 13世纪初期,意大利数论家Leonardo Fibonacci在他的著作Liber Abaci中提出了兔子的繁殖问题: 如果一开始有一对刚出生的兔子,兔子的长大需要一个月,长大后的兔子每个月能生产一对兔子,假设兔子不会死亡,那么一年后有多少只兔子? 不难看出每个月的兔子的总数可以用以下数列表示:1,1,2,3,5,8,13...... 二:最直观的算法 1.算法实现 通过观察我们不难发现斐波那契数列从第三项开始每一项都是前两项的和,因此我们不难总结出该数列的递推公式:

斐波那契数列问题的两种解决方法

斐波那契数列指的是这样一个数列 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368........ 这个数列从第3项开始,每一项都等于前两项之和. 简单来说,斐波那契数列可以用下面这个公式来表示. { 0 ,n=0 f(n)={ 1 ,n=1 { f(n-1)+f(n-2) ,n>1 关于斐波那契数列衍生的算法题层出不穷,比如青蛙跳台阶问题等(

js算法集合(二) javascript实现斐波那契数列 (兔子数列) Javascript实现杨辉三角

js算法集合(二)  斐波那契数列.杨辉三角 ★ 上一次我跟大家分享一下做水仙花数的算法的思路,并对其扩展到自幂数的算法,这次,我们来对斐波那契数列和杨辉三角进行研究,来加深对Javascript的理解. 一.Javascript实现斐波那契数列 ①要用Javascript实现斐波那契数列,我们首先要了解什么是斐波那契数列:斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为

《BI那点儿事》Microsoft 时序算法——验证神奇的斐波那契数列

斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368斐波那契数列的发明者,是意大利数学家列昂纳多·斐波那契(Leonardo Fibonacci),生于公元1170年,卒于1250年,籍贯是比萨.他被人称作“比萨的列昂纳多”.1202年,他撰写了<算盘全书>(Liber Abacci)一书.他是第一个研究了

斐波那契数列公式算法-JS实现

之前算斐波那契数列都是算前两个数相加实现的 比如0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368 2=1+1 3=1+2 5=2+3 8=3+5 …… 其实还有另外一个规律: 2 = 1*2-03 = 2*2-15 = 3*2-18 = 5*2-213= 8*2-321=13*2-5 …… 下面是JS实现的代码: <!DOCTYPE h

算法——动态规划篇——斐波那契数列

斐波那契数列,又称黄金分割数列,指的是这样一个数列:0.1.1.2.3.5.8.13.21.--在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1,Fn=F(n-1)+F(n-2)(n>=2,n∈N*)在现代物理.准晶体结构.化学等领域,斐波纳契数列都有直接的应用,为此,美国数学会从1960年代起出版了<斐波纳契数列>季刊,专门刊载这方面的研究成果. 以上内容来自百度百科.. 今天主要是想用动态规划的思想求解斐波那契数列,用来观察动态规划带来的优势,空间换时间,不重复求解

最优化算法-斐波那契数列搜索

斐波那契数列搜索,参考Edwin<最优化导论>第四版7.3章节,算法采用go语言实现. /***************************************** * FileName : fibonacci_search.go * Author : fredric * Date : 2017.09.01 * Note : 斐波那契数列搜索算法 * History : *****************************************/ package search

算法题---k阶斐波那契数列

#include <iostream> #include <cstdio> #include <stdlib.h> #include <algorithm> using namespace std; int main() { int a[120]; int k, m; while (1) { cout << "输入阶数k和约定的常数max.k和max用空格分开." << endl; cin >> k &