随笔 - 136  文章 - 0  评论 - 82  阅读 - 10万

POJ3070 斐波那契数列递推 矩阵快速幂模板题

题目分析:

对于给出的n,求出斐波那契数列第n项的最后4为数,当n很大的时候,普通的递推会超时,这里介绍用矩阵快速幂解决当递推次数很大时的结果,这里矩阵已经给出,直接计算即可

复制代码
 1 #include<iostream>
 2 #include<stdio.h>
 3 using namespace std;
 4 
 5 const int mod = 10000;
 6 struct mat{
 7     int m[2][2];
 8 };
 9 
10 mat operator * (mat a, mat b){        //重载乘号,同时将数据mod10000 
11     mat ret;
12     for(int i = 0; i < 2; i++){
13         for(int j = 0; j < 2; j++){
14             long long temp = 0;
15             for(int k = 0; k < 2; k++){
16                 temp += a.m[i][k] * b.m[k][j];
17                 temp %= mod;
18             }
19             ret.m[i][j] = temp;
20         }
21     }    
22     return ret;
23 }
24 
25 mat pow_mat(mat a, int n){        //矩阵快速幂和快速幂相同(广义快速幂的思想) 
26     mat res = a;
27     while(n){
28         if(n&1) res = res * a;
29         a = a*a;
30         n >>= 1;
31     }
32     return res;
33 }
34 
35 int main(){
36     int n;
37     while(scanf("%d", &n) !=EOF){
38         if(n == -1) break;
39         if(n == 0) printf("0\n");
40         else if(n == 1) printf("1\n");
41         else if(n == 2) printf("1\n");
42         else{
43             mat a;                            //构造一个初始的矩阵 其n-2次方的m[0][0]就是所求的答案 
44             a.m[0][0] = 1;
45             a.m[0][1] = 1;
46             a.m[1][0] = 1;
47             a.m[1][1] = 0;
48             mat ans = pow_mat(a, n-2);        //调用矩阵快速幂计算 
49             printf("%d\n", ans.m[0][0]);
50         }
51     }
52     return 0;
53 }
复制代码

 

posted on   白泽talk  阅读(230)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET10 - 预览版1新功能体验(一)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示