斐波那契(快速矩阵幂)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言

提示:这里可以添加本文要记录的大概内容:

斐波那契数列就是前面俩个数字相加,例如1,1,2,3,5,8,11...

(前面俩个1要相等


提示:以下是本篇文章正文内容,下面案例可供参考

一、斐波那契数列代码

java 复制代码
public class FibonacciSeries {  
    public static void main(String[] args) {  
        int n = 10; // 你可以改变这个值来计算斐波那契数列的前n个数  
        printFibonacciSeries(n);  
    }  
  
    public static void printFibonacciSeries(int n) {  
        int t1 = 0, t2 = 1;  
        System.out.print("斐波那契数列的前 " + n + " 个数是:");  
  
        for (int i = 1; i <= n; ++i) {  
            System.out.print(t1 + " ");  
            int sum = t1 + t2;  
            t1 = t2;  
            t2 = sum;  
        }  
    }  
}

二、矩阵快速幂(斐波那契)

AcWing 1305. 1303. 斐波那契前 n 项和

前面这个base是指的是(fn,f(n+1),Sn))

res是推出来的公式,由于矩阵乘法中,是列*行=得到的数;

代码如下(示例):

c 复制代码
public class Main{
    static int m ;
    public static void main(String[] args){
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        m = input.nextInt();
        //1 1 2  3
        long[][] matrix = cal(n-1);
        // for(int i = 0 ; i < 3 ; i++){
        //     System.out.println(Arrays.toString(matrix[i]));
        // }
        long res = 0;
        for(int i = 0 ; i < 3 ; i++){
            res = (res + matrix[i][2]) % m;
        }
        System.out.println(res);

    }
    public static  long[][] cal(int n ){
        long[][] base = {{0,1,0},{1,1,1},{0,0,1}};
        long[][] res = {{1,0,0},{0,1,0},{0,0,1}};
        while(n > 0){
            if((n & 1) == 1){
                res = multi(res,base);
            }
            n = n >> 1;
            base = multi(base,base);
        }
        return res;
    }
    public static long[][] multi(long[][] A,long[][] B){
        long[][] res = new long[A.length][B[0].length];
        for(int i = 0 ; i < A.length ; i++){
            for(int j = 0 ; j < B[0].length ; j++){
                for(int k = 0 ; k < A[0].length ; k++){
                    res[i][j] = (res[i][j] + A[i][k] * B[k][j]) % m;
                }
            }
        }
        return res;
    }
}

相关推荐
莹莹学编程—成长记2 小时前
string的模拟实现
服务器·c++·算法
lybugproducer2 小时前
创建型设计模式之:简单工厂模式、工厂方法模式、抽象工厂模式、建造者模式和原型模式
java·设计模式·建造者模式·简单工厂模式·工厂方法模式·抽象工厂模式·面向对象
南客先生2 小时前
马架构的Netty、MQTT、CoAP面试之旅
java·mqtt·面试·netty·coap
Minyy112 小时前
SpringBoot程序的创建以及特点,配置文件,LogBack记录日志,配置过滤器、拦截器、全局异常
xml·java·spring boot·后端·spring·mybatis·logback
百锦再2 小时前
Java与Kotlin在Android开发中的全面对比分析
android·java·google·kotlin·app·效率·趋势
武昌库里写JAVA3 小时前
39.剖析无处不在的数据结构
java·vue.js·spring boot·课程设计·宠物管理
星云ai4 小时前
矩阵运营:抢占市场与流量的利器
矩阵
Nelson_hehe5 小时前
Java基础第四章、面向对象
java·语法基础·面向对象程序设计
Thomas_YXQ5 小时前
Unity3D Lua集成技术指南
java·开发语言·驱动开发·junit·全文检索·lua·unity3d
ShiinaMashirol6 小时前
代码随想录打卡|Day27(合并区间、单调递增的数字、监控二叉树)
java·算法