矩阵乘法&&矩阵快速幂

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&矩阵乘法&快速幂)

Luogu P3390 模板矩阵快速幂&&P1939 模板矩阵加速(数列)

模板——矩阵快速幂+矩阵乘法

UVa 10870 & 矩阵快速幂

矩阵快速幂模板

矩阵快速幂