问题描述:斐波那契数列是这样的一个数列,1,1,2,3,5,8,..,即前两项都是1,后面每一项都是其前面两项的和。

现在要你求出该数列的第n项。

分析:该问题是一个经典的数列问题,相信大家在很多语言的教科书上都碰到过这个练习题目。这里我给大家总结了三种经典解法,并对这三个方法进行了对比。

解法一:递归算法。很多教科书上都用这个题作为函数递归知识点讲解的例题,我们可以将每一个项的求法表达为这样一个式子:

f(n)=f(n-1)+f(n-2),f(1)=1,f(2)=1,可以看出,可以采用递归算法求解。

 解法二:循环求法。我们可以从第1项开始,一直求到第n项,即可,一个循环可以做到,时间复杂度为O(n).

解法三:矩阵链乘法。如果线性代数学的好的话,可以想出这样一种解法,

同样可以采用递归的算法求解,时间复杂度为O(logn).

三种解法对比:解法一编程最简单,但是效率最低,因为这种递归算法求解时,会重复求解子问题。如下图示:

这样就看出来吧!另外如果n很大的话,递归的层数很大,会消耗系统大量的时间和资源。

解法二避免了重复求解子问题,线性时间即可求出,值得采用。

解法三效率最高,但是编程特别复杂,在有些情况下,很合适使用,但就本题目来说,推荐解法二。

针对上述三种解法,我给出了详细的Java代码,读者可以参考:

 import java.util.*;
public class Main {
public static int f1(int n){ //方法一:递归算法,自底向上
if(n<=2)return 1; //如果是求前两项,直接返回就可
else return f1(n-1)+f1(n-2);
}
public static int f2(int n){ //方法二:循环算法,自上而下
if(n<=2)return 1; //如果是求前两项,直接返回就可
int a1=1,a2=1,a3;
for(int i=3;i<=n;i++)
{
a3=a1+a2;
a1=a2;
a2=a3;
}
return a2;
}
public static int[][] f3(int n){ //方法三:矩阵链相乘算法,采用递归实现
int a[][]={{1,1},{1,0}}; //定义基矩阵
int b[][]; //存储子方法的结果
int c[][]=new int[2][2]; //存储最后计算结果
int d[][]=new int[2][2]; //存储中间计算结果
if((n)<=1)return a; //如果次方小等于1直接返回
else if((n) %2==1)
{b=f3((n-1)/2); d[0][0]=b[0][0]*b[0][0]+b[0][1]*b[1][0];
d[0][1]=b[0][0]*b[0][1]+b[0][1]*b[1][1];
d[1][0]=b[1][0]*b[0][0]+b[1][1]*b[1][0];
d[1][1]=b[1][0]*b[0][1]+b[1][1]*b[1][1]; c[0][0]=d[0][0]*a[0][0]+d[0][1]*a[1][0];
c[0][1]=d[0][0]*a[0][1]+d[0][1]*a[1][1];
c[1][0]=d[1][0]*a[0][0]+d[1][1]*a[1][0];
c[1][1]=d[1][0]*a[0][1]+d[1][1]*a[1][1]; }
else {
b=f3((n)/2); c[0][0]=b[0][0]*b[0][0]+b[0][1]*b[1][0];
c[0][1]=b[0][0]*b[0][1]+b[0][1]*b[1][1];
c[1][0]=b[1][0]*b[0][0]+b[1][1]*b[1][0];
c[1][1]=b[1][0]*b[0][1]+b[1][1]*b[1][1];
}
return c;
}
public static void main(String[] args) {
// TODO 自动生成的方法存根
Scanner scan=new Scanner(System.in);
int n=scan.nextInt();
System.out.println("方法一:"+f1(n));
System.out.println("方法二:"+f2(n));
int a[][]=f3(n-1); //因为是要求矩阵{{1,0},{1,0}}的n-1次方
System.out.println("方法三:"+a[0][0]); } }

输出结果为:

10
方法一:55
方法二:55
方法三:55

求斐波那契数列的第n项的更多相关文章

  1. Problem R: 求斐波那契数列的前n项值

    #include<stdio.h> int main() { int n; while(scanf("%d",&n)!=EOF){ int x1,x2,i,x; ...

  2. 黑马入学基础测试(三)求斐波那契数列第n项,n<30,斐波那契数列前10项为 1,1,2,3,5,8,13,21,34,55

    .获得用户的输入 计算      3打印就行了.   这里用到了java.util.Scanner   具体API  我就觉得不常用.解决问题就ok了.注意的是:他们按照流体的方式读取.而不是刻意反复 ...

  3. 01-封装函数求斐波那契数列第n项

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  4. C# 求斐波那契数列的前10个数字 :1 1 2 3 5 8 13 21 34 55

    //C# 求斐波那契数列的前10个数字 :1 1 2 3 5 8 13 21 34 55 using System; using System.Collections.Generic; using S ...

  5. 【poj3070】矩阵乘法求斐波那契数列

    [题目描述] 我们知道斐波那契数列0 1 1 2 3 5 8 13…… 数列中的第i位为第i-1位和第i-2位的和(规定第0位为0,第一位为1). 求斐波那契数列中的第n位mod 10000的值. [ ...

  6. golang 闭包求斐波那契数列

    题目是Go指南中的闭包求斐波那契数列 package main import "fmt" // 返回一个"返回int的函数" func fibonacci() ...

  7. 用JS,求斐波那契数列第n项的值

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  8. 51 Nod 1242 斐波那契数列的第N项(矩阵快速幂模板题)

    1242 斐波那契数列的第N项  基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 斐波那契数列的定义如下: F(0) = 0 F(1) = 1 F(n) ...

  9. 1242 斐波那契数列的第N项

    1242 斐波那契数列的第N项  基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题   斐波那契数列的定义如下:   F(0) = 0 F(1) = 1 F(n) = F( ...

随机推荐

  1. Android 打造自己的个性化应用(三):应用程序的插件化

    在android的项目开发中,都会遇到后期功能拓展增强与主程序代码变更的现实矛盾,也就是程序的灵活度. 由于linux平台的安全机制,再加上dalvik的特殊机制,各种权限壁垒,使得开发一个灵活多变的 ...

  2. [Python学习笔记][第五章Python函数设计与使用]

    2016/1/29学习内容 第四章 Python函数设计与使用 之前的几页忘记保存了 很伤心 变量作用域 -一个变量已在函数外定义,如果在函数内需要修改这个变量的值,并将这个赋值结果反映到函数之外,可 ...

  3. 无法登陆mysql服务器

    解决 .#2002 无法登录 MySQL 服务器 将config.sample.inc.php复制成config.inc.php 出现这个错误,表示没有连接到数据库.修改config.inc.php文 ...

  4. 玩转Nodejs日志管理log4js(转)

    转自:http://blog.fens.me/nodejs-log4js/ 前言 日志对任何的应用来说都是至关重要的.在Nodejs中使用express框架并没有自带的日志模块,我们可以选择log4j ...

  5. css基本选择器

    CSS:层叠样式表 (Cascading Style Sheets) 结构层:HTML表现层: CSS行为层: DOM,JavaScript CSS语法结构:div{background:#f00;} ...

  6. 学习使用Vim(二)——User Manuals, Getting Started

    Vim的用户手册主要包含以下三个部分:     Getting Started;     Editing Effectively;     Tuning Vim;     分别代表基本编辑技巧,更优化 ...

  7. [hdu5136]Yue Fei's Battle 2014 亚洲区域赛广州赛区J题(dp)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud 现场赛的时候由于有个地方有点小问题,没有成功AC,导致与金牌失之交臂. 由于今天下 ...

  8. 何时可以开启透明数据加密(TDE)?

    TDE可以为我们的数据库提供加密保护,但是,不是任何情况下都可以随意开启TDE的,同时开启TDE后,我们的数据库维护管理工作也需要进行一些调整. 下面我们就先看看开启TDE需要的条件吧! 无法正常开启 ...

  9. Laravel 实现 Facades 功能

    使用过Laravel的同学都知道Facades 的强大,下面就让我们一起创建一个Facades 实例.如有不正确的地方,还请不吝赐教. 1. 实现Laravel的自动加载功能 首先建立目录app/li ...

  10. 【转】实战Nginx与PHP(FastCGI)的安装、配置与优化

    原文连接:http://ixdba.blog.51cto.com/2895551/806622 原文作者:南非蚂蚁 转载注明以上信息 一.什么是 FastCGIFastCGI是一个可伸缩地.高速地在H ...