Matrix Power Series

r时间限制: 1 Sec 内存限制: 512 MB

题目描述

给定矩阵A,求矩阵S=A1+A2+……+A^k,输出矩阵,S矩阵中每个元都要模m。

数据范围: n (n ≤ 30) , k (k ≤ 109) ,m (m < 104)

输入

输入三个正整数n,k,m

输出

输出矩阵S mod m

样例输入

2 2 4

0 1

1 1

样例输出

1 2

2 3

这道题不多说,可以得出加速矩阵(E为单位矩阵,也就是形为\(\begin{bmatrix}1&0&...&0\\0&1&...&0\\... &...&...&...\\0&0& ...&1\end{bmatrix}\)的矩阵,任何矩阵乘以这个单位矩阵还是原矩阵):

\(\begin{bmatrix}
A &E \\
0 & E
\end{bmatrix}\)*\(\begin{bmatrix} A &E \\ 0 & E \end{bmatrix}\)=\(\begin{bmatrix} A^{2} &E+A \\ 0 & E \end{bmatrix}\)

所以根据题目的要求,答案便是\(\begin{bmatrix}
A &E \\
0 & E
\end{bmatrix}^{k+1}\)的(1,2)

主要难点是矩阵套矩阵,详见代码:

#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std; #define N 35
#define P 5
#define LL long long LL fuck,k,mod; struct M {
int n,m,c[N][N];
M() {
n=m=fuck;
memset(c,0,sizeof(c));
}
M operator * (const M& a) {
M r;
r.n=n;r.m=a.m;
for(int i=1;i<=r.n;i++)
for(int j=1;j<=r.m;j++)
for(int k=1;k<=m;k++)
r.c[i][j]= ( r.c[i][j] + (c[i][k] * a.c[k][j] ) % mod) % mod;
return r;
}
M operator + (const M& a) {
M r;
for(int i=1;i<=r.n;i++)
for(int j=1;j<=r.m;j++)
r.c[i][j]=(c[i][j]+a.c[i][j]) %mod;
return r;
}
M operator - (const M& a) {
M r;
for(int i=1;i<=r.n;i++)
for(int j=1;j<=r.m;j++)
r.c[i][j]=r.c[i][j]+(mod+c[i][j]-a.c[i][j]) %mod;
return r;
}
void _read() {
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
scanf("%lld",&c[i][j]);
}
void pre() {
n=m=fuck;
for(int i=1;i<=fuck;i++)
c[i][i]=1;
}
void _print() {
for(int i=1;i<=n;i++) {
for(int j=1;j<=m;j++) {
if(j!=1) cout<<" ";
cout<<c[i][j];
}
if(i!=n) puts("");
}
puts("");
}
}fuckk; struct Matrix {
LL n,m;
M c[P][P];
Matrix() {
m=2,n=2;
memset(c,0,sizeof(c));
};
Matrix operator * (const Matrix& a) {
Matrix r;
r.n=n;r.m=a.m;
for(int i=1;i<=r.n;i++)
for(int j=1;j<=r.m;j++)
for(int k=1;k<=m;k++)
r.c[i][j]=r.c[i][j] + (c[i][k] * a.c[k][j] );
return r;
} Matrix pow(Matrix a, LL indexx) {
Matrix sum;sum.n=sum.m=2;
sum.c[1][1].pre();
sum.c[2][2].pre();
//a.c[1][2]._print();
while(indexx>0) {
if(indexx&1) sum=sum*a;
/*sum.c[1][1]._print();
sum.c[1][2]._print();
sum.c[2][1]._print();
sum.c[2][2]._print();*/
a=a*a;
//a.c[1][1]._print();
indexx/=2;
}
return sum;
}
void sub() {
c[1][2]=c[1][2]-fuckk;
} }ans; int main() {
cin>>fuck>>k>>mod;
M a,b;
a._read();
b.pre();
fuckk=b;
ans.c[1][1]=a;
ans.c[1][2]=ans.c[2][2]=b;
//ans.test(ans);
ans=ans.pow(ans,k+1);
//ans.c[1][2]._print();
ans.sub();
ans.c[1][2]._print();
}

C++题解:Matrix Power Series ——矩阵套矩阵的矩阵加速的更多相关文章

  1. Poj 3233 Matrix Power Series(矩阵乘法)

    Matrix Power Series Time Limit: 3000MS Memory Limit: 131072K Description Given a n × n matrix A and ...

  2. 矩阵十点【两】 poj 1575 Tr A poj 3233 Matrix Power Series

    poj 1575  Tr A 主题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1575 题目大意:A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的 ...

  3. POJ 3233 Matrix Power Series (矩阵乘法)

    Matrix Power Series Time Limit: 3000MS   Memory Limit: 131072K Total Submissions: 11954   Accepted:  ...

  4. 构造矩阵解决这个问题 【nyoj299 Matrix Power Series】

    矩阵的又一个新使用方法,构造矩阵进行高速幂. 比方拿 nyoj299 Matrix Power Series 来说 给出这样一个递推式: S = A + A2 + A3 + - + Ak. 让你求s. ...

  5. POJ 3233 Matrix Power Series(矩阵快速幂)

    Matrix Power Series Time Limit: 3000MS Memory Limit: 131072K Total Submissions: 19338 Accepted: 8161 ...

  6. POJ 3233 Matrix Power Series 【经典矩阵快速幂+二分】

    任意门:http://poj.org/problem?id=3233 Matrix Power Series Time Limit: 3000MS   Memory Limit: 131072K To ...

  7. [ACM] POJ 3233 Matrix Power Series (求矩阵A+A^2+A^3...+A^k,二分求和或者矩阵转化)

    Matrix Power Series Time Limit: 3000MS   Memory Limit: 131072K Total Submissions: 15417   Accepted:  ...

  8. poj 3233 Matrix Power Series(矩阵二分,高速幂)

    Matrix Power Series Time Limit: 3000MS   Memory Limit: 131072K Total Submissions: 15739   Accepted:  ...

  9. [POJ3233]Matrix Power Series 分治+矩阵

    本文为博主原创文章,欢迎转载,请注明出处 www.cnblogs.com/yangyaojia [POJ3233]Matrix Power Series 分治+矩阵 题目大意 A为n×n(n<= ...

随机推荐

  1. JPA报错问题修改小结

    项目中在使用线程跑定时任务时,遇到报错,"Could not open JPA EntityManager for transaction Caused by: org.hibernate. ...

  2. python中的全局变量和局部变量

    python中,对于变量作用域的规定有些不一样. 在诸如C/C++.java等编程语言中,默认在函数的内部是能够直接訪问在函数外定义的全局变量的,可是这一点在python中就会有问题.以下是一个样例. ...

  3. rem_750

    /* fix the code flash the page */ var globalWidth = document.documentElement.clientWidth;//window.in ...

  4. 小A与小B-(双向bfs)

    链接:https://ac.nowcoder.com/acm/contest/549/G来源:牛客网 题目描述 小A与小B这次两个人都被困在了迷宫里面的两个不同的位置,而他们希望能够迅速找到对方,然后 ...

  5. docker学习-常用命令2

    三.容器管理命令3.1 Docker commit 命令,从容器创建一个新的镜像.OPTIONS说明: -a :提交的镜像作者: -c :使用Dockerfile指令来创建镜像: -m :提交时的说明 ...

  6. 【JDBC】java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone.

    在使用阿里的druid 时,报了一个异常java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized ...

  7. material palette

    https://www.materialpalette.com/

  8. mysql7.5.x删除重新安装

    删除: cmd管理员运行,进入D:\devs\MySQL\mysql-5.7.25-winx64\bin目录下: 输入命令:sc delete mysql 删除data目录下的所有文件 安装: 创建m ...

  9. spring-boot的Hello World案例,最简单的spring-boot项目

    Spring Boot HelloWorld 一个功能: 浏览器发送hello请求,服务器接收请求并处理,响应Hello World字符串. 1.创建一个maven项目 2.导入依赖spring-bo ...

  10. Linux 学习笔记 1

    1.  名词解释 GNU: 目标是创建一套完全自由的操作系统:包含了可自由使用的软件,如Emacs,GCC,Tex,X Window:制定了3个自由软件协议:GPL,LGPL,GFDL GPL(Gen ...