矩阵乘法&&矩阵快速幂
Posted Heilce
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了矩阵乘法&&矩阵快速幂相关的知识,希望对你有一定的参考价值。
int add(long long &x,long long y) { x+=y; x%=MOD; } Matrix mutil(Matrix x,Matrix y) { Matrix z; memset(z.a,0,sizeof(z.a)); for(int i=0;i<X;i++) { for(int k=0;k<X;k++) { if(x.a[i][k]==0) continue; for(int j=0;j<X;j++) { add(z.a[i][j],x.a[i][k]*y.a[k][j]); } } } return z; } Matrix Pow(Matrix x,int n) { Matrix y; for(int i=0;i<X;i++) y.a[i][i]=1; while(n) { if(n&1) y=mutil(x,y); x=mutil(x,x); n=n/2; } return y; }
以上是关于矩阵乘法&&矩阵快速幂的主要内容,如果未能解决你的问题,请参考以下文章
ZOJ - 3216:Compositions (DP&矩阵乘法&快速幂)