之前写了一篇从斐波那契数列分析递归与动态规划(JAVA)来优化斐波那契数列,这样可以使算法的时间复杂度从O(n^2)变到O(n),这是使用递归公式f(n)=f(n-1)+f(n-2)求斐波那契数列的最优算法,但是这只是一维世界下的极限。下面我们将其从一维上升到二维,用二阶矩阵推导斐波那契数列,该算法的复杂度为O(logn)。

矩阵定义

一个m*n的矩阵是一个由m行n列元素排成的矩形阵列。矩阵里的元素可以是数字符号或者数学式.

下面是一个典型的二阶矩阵

二阶矩阵的乘法

高效幂运算


第一种方法在高效幂运算(JAVA)中有类似的描述,虽然本文中是对矩阵进行幂运算,实质是一样的

第二种方法利用位运算转换成二进制处理

斐波那契数列的矩阵算法

import java.util.Scanner;/***  [F(n+1) F(n)]    [1  1 ]^n|           |   =|     |[F(n) F(n-1)]    [1  0 ]* */
public class Main {// 公式矩阵  private static final int[][] UNIT = {{1, 1}, {1, 0}};// 零矩阵  private static final int[][] ZERO = {{0, 0}, {0, 0}};public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt();int[][] m = fb(n);System.out.println(m[0][1]);}/*** 利用二进制进行高效幂运算* 求斐波那契数列* */public static int[][] fb(int n) {if (n == 0) {return ZERO;}if (n == 1) {return UNIT;}if (n%2 == 0) {System.out.println(n >> 1);int[][] matrix = fb(n >> 1);return Multiply(matrix, matrix);} else {int[][] matrix = fb((n - 1) >> 1);return Multiply(Multiply(matrix, matrix), UNIT);}}/*** 矩阵乘法* */public static int[][] Multiply(int[][] m, int[][] n) {/*** 对于斐波那契数列来说,行和列都是2,这样写更易于理解,下面也给出了标准的矩阵乘法算法,是通用的* 用到此算法,除非进行算法学习和研究,否则一般都是进行较大数据的斐波那契求值,所以对结果取(10e9)+7的模* */int[][] r = new int[2][2];r[0][0] = (m[0][0]*n[0][0] + m[0][1]*n[1][0])%1000000007;r[0][1] = (m[0][0]*n[0][1] + m[0][1]*n[1][1])%1000000007;r[1][0] = (m[1][0]*n[0][0] + m[1][1]*n[1][0])%1000000007;r[1][1] = (m[1][0]*n[0][1] + m[1][1]*n[1][1])%1000000007;return r;}
}

标准矩阵乘法算法:

    public static int[][] Multiply(int[][] m, int[][] n) {
//        标准计算矩阵乘法算法int rows = m.length;int cols = n[0].length;int[][] r = new int[rows][cols];for (int i = 0; i < rows; i++) {for (int j = 0; j < cols; j++) {r[i][j] = 0;for (int k = 0; k < m[i].length; k++) {r[i][j] += m[i][k] * n[k][j];}}}return r;}
}

斐波那契数列(二)--矩阵优化算法相关推荐

  1. “斐波那契数列”的两种算法

    "斐波那契数列"的两种算法 斐波那契数列有个规律:从第三个数开始,每个数是前两个数之和,比如: 1 1 2 3 5 8 13 21 34 55...... 现在通过两种方式(递归与 ...

  2. 加强版斐波那契数列(矩阵快速幂)

    关于快速幂的讲解可以参见我的上一篇博客<快速幂> 题目链接:又见斐波那契 题目描述 这是一个加强版的斐波那契数列. 给定递推式 求F(n)的值,由于这个值可能太大,请对10 9+7取模. ...

  3. hdu 4549 M斐波那契数列(矩阵乘法+降幂公式)

    Problem Description M斐波那契数列F[n]是一种整数数列,它的定义如下: F[0] = a F[1] = b F[n] = F[n-1] * F[n-2] ( n > 1 ) ...

  4. 斐波那契数列和矩阵的特征值于特征向量的关系

    从事软件开发的人对斐波那契数列可以说在熟悉不过了,一般是学习递归算法的入门案例写在教科书中,它用递推公式表达是这个样子的: 作为一名自尊自爱的码农,看到这个公式不免既心痒又难骚,必须要安排它一下,就拿 ...

  5. JS用For循环实现斐波那契数列(及尾递归优化)

    斐波那契数列指的是这样一个数列:1.1.2.3.5.8.13.21.34.--在数学上,斐波纳契数列以如下被以递推的方法定义:F(1)=1,F(2)=1, F(n)=F(n-1)+F(n-2)(n&g ...

  6. 兔子数列(斐波那契数列)的优化

    当使用递归实现斐波那契数列时无限调用会使内存无限占用 不优化会数太大就会内存占满导致网页很卡,递归的的数据结构又是二叉树,调用执行重复的使用值,优化把已经得到的值,存到对象里,下一次取就不用递归了. ...

  7. php算法求出兔子数列,PHP算法:斐波那契数列的N种算法

    前言 前段时间,遇到优化计算斐波那契数列的常规递归方法,但是一时间并没有及时想到很好的方法,所以后面查找了相关资料,总结了多种计算解法,所以分享出来,和大家一起交流学习. 斐波那契数是什么 斐波那契数 ...

  8. C语言中经典算法——斐波那契数列的几种算法

    斐波那契数列的递推公式: 我们尝试计算斐波那契数列的第n项并输出. 1.递归法 #include<stdio.h> int fib(int m) {if(m>=3){return f ...

  9. 斐波那契数列谈矩阵(1)

    斐波那契序列 集锦 (转) [定理1] 标准Fibonacci序列(即第0项为0,第1项为1的序列)当N大于1时,一定有f(N)和f(N-1)互质 其实,结合"互质"的定义,和一个 ...

  10. 斐波那契数列时间复杂度Logn的算法

    矩阵分解 class Solution {static final int MOD = 1000000007;public int fib(int n) {if (n < 2) {return ...

最新文章

  1. 前端npm 安装包,精选大全集合
  2. NGINX、PHP-FPM开机自动启动
  3. 【Linux 内核】进程管理 - 进程优先级 ② ( prio 调度优先级 | static_prio 静态优先级 | normal_prio 正常优先级 | rt_priority 实时优先级 )
  4. M2 Scrum 12.05
  5. angular路由笔记_Angular2学习笔记——路由器模型(Router)
  6. 人工计算机的相关信息,第三届计算机信息科学与人工智能国际学术会议(CISAI 2020)...
  7. MyMathLib系列(行列式计算2)
  8. 如何修复MySQL配置文件?
  9. 【深入理解JS核心技术】3. 调用、应用和绑定有什么区别
  10. linux运行raxml,在线和本地两种方法构建 RAxML 进化树方法和解读
  11. RS法计算Hurst指数
  12. Android使用网络打印机打印
  13. 水水水水水水水水水水水水水水水水水水水
  14. 红米K30 Pro再次降价700元,小米加速收割5G手机市场
  15. 【今日收获】关于[Error] expected identifier before ‘*‘ token的解决办法
  16. 什么是数据库“存算分离”架构?
  17. 双臂路由实现vlan间通信
  18. MATLAB 车牌识别程序介绍 SVM、神经网络[毕业设计]
  19. 微信小程序之图表系列——最简单的表格制作
  20. shift delete删除的文件怎么恢复,神操作只用一招

热门文章

  1. 利用trunk实现vlan内通信_实现不同VLAN间通信——单臂路由
  2. mysql in 多个字段_MySQL如何同时自增自减多个字段
  3. 计算机中的字,双字以及存储
  4. ols残差_涨知识丨OLS原理的矩阵方法很难?Just So So
  5. 基于 java springboot+mybatis二手物品网站系统设计和实现
  6. linux如何卸载conky,Linux Deepin 15.10.2 下折腾 简单自制的 Conky Conky-manager
  7. css居中的几种方法_CSS几种常用的水平垂直居中对齐方法
  8. 计算机专业的求职信英文作文,计算机专业本科英文求职信范文
  9. jframe运行和预览大小不一样_同一款车型,为什么配的轮胎大小还会不一样?【内含福利】...
  10. 服务器购买和远程连接