NYOJ 1075 (递推 + 矩阵快速幂)
生活随笔
收集整理的這篇文章主要介紹了
NYOJ 1075 (递推 + 矩阵快速幂)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
“紅色病毒”問題
時間限制:1000?ms ?|? 內存限制:65535?KB 難度:4 描述#include<cstdio> #include<cstring>#define mod 10007struct Matrix {int mat[4][4];Matrix() {memset(mat, 0, sizeof(mat));for(int i = 0; i < 4; i++)mat[i][i] = 1;} };Matrix Multi(Matrix a, Matrix b) {Matrix res;for(int i = 0; i < 4; i++) {for(int j = 0; j < 4; j++) {res.mat[i][j] = 0;for(int k = 0; k < 4; k++) {res.mat[i][j] += a.mat[i][k] * b.mat[k][j];res.mat[i][j] %= mod;}}}return res; }Matrix Pow(Matrix a, int x) {Matrix res;while(x) {if(x&1) res = Multi(res, a);a = Multi(a, a);x >>= 1;}return res; }int main() {int T, n;Matrix A; //系數矩陣A.mat[0][0] = 2; A.mat[0][1] = 1; A.mat[0][2] = 1; A.mat[0][3] = 0;A.mat[1][0] = 1; A.mat[1][1] = 2; A.mat[1][2] = 0; A.mat[1][3] = 1;A.mat[2][0] = 1; A.mat[2][1] = 0; A.mat[2][2] = 2; A.mat[2][3] = 1;A.mat[3][0] = 0; A.mat[3][1] = 1; A.mat[3][2] = 1; A.mat[3][3] = 2;scanf("%d",&T);while(T--) {scanf("%d", &n);Matrix ans = Pow(A, n);printf("%d\n", ans.mat[0][0]);}return 0; }
總結
以上是生活随笔為你收集整理的NYOJ 1075 (递推 + 矩阵快速幂)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: IDEA新特性:提前知道代码怎么走!
- 下一篇: NYOJ 1085 数单词 (AC自动机