码迷,mamicode.com
首页 > 其他好文 > 详细

[luogu] 斐波那契数列

时间:2017-12-30 18:08:53      阅读:82      评论:0      收藏:0      [点我收藏+]

标签:std   set   eof   sizeof   post   www.   opera   problem   mod   

https://www.luogu.org/problemnew/show/P1962

矩阵快速幂加速

#include <bits/stdc++.h>

using namespace std;

#define gc getchar()
#define LL long long

const LL mod = 1000000007;

LL n, s;

inline LL read(){
    LL x = 0; char c = gc;
    while(c < 0 || c > 9) c = gc;
    while(c >= 0 && c <= 9) x = x * 10 + c - 0, c = gc;
    return x;
}

struct Node{
    LL m[3][3];
    Node() { memset(m,0,sizeof m);}
    void clear(){for(int i = 1; i <= n; i ++) m[i][i] = 1;}
};

Node operator *(Node a, Node b){
    Node ret;
    for(int i = 1; i <= n; i ++)
        for(int j = 1; j <= n; j ++)
            for(int k = 1; k <= n; k ++)
                ret.m[i][j] = (ret.m[i][j] + a.m[i][k] * b.m[k][j]) % mod;
    return ret;
}

Node ksm(Node a, LL p){
    Node ret; ret.clear();    
    while(p){
        if(p & 1) ret = ret * a;
        a = a * a;
        p >>= 1;
    }
    return ret;
}

int main()
{
     s = read();
    n = 2;
    Node a, b;
    a.m[1][1] = 0; a.m[1][2] = 1; a.m[2][1] = 1; a.m[2][2] = 1;
    b.m[1][1] = 1; b.m[2][1] = 1;
    Node Ans;
    Ans = ksm(a, s - 1);
    Node answer = Ans * b;
    cout << answer.m[1][1];

    return 0;
}

 

[luogu] 斐波那契数列

标签:std   set   eof   sizeof   post   www.   opera   problem   mod   

原文地址:https://www.cnblogs.com/shandongs1/p/8150229.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!