bzoj2396: 神奇的矩阵(矩阵乘法+随机化)

Posted Sakits

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了bzoj2396: 神奇的矩阵(矩阵乘法+随机化)相关的知识,希望对你有一定的参考价值。

  这题n三方显然会GG...

  运用矩阵乘法的性质A*B*R=A*(B*R)=C*R,于是随机化出一个一列的R,就可以把复杂度降低成n方...大概率是不会错的

技术分享
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio> 
#include<algorithm>
#define ll long long 
using namespace std;
const int maxn=510,inf=1e9;
typedef int mtx[maxn][maxn];
int n,m,x,y,z,tot;
mtx f,a,b,c;
void read(int &k)
{
    int f=1;k=0;char c=getchar();
    while(c<0||c>9)c==-&&(f=-1),c=getchar();
    while(c<=9&&c>=0)k=k*10+c-0,c=getchar();
    k*=f;
}
void mul(mtx &a,mtx b)
{
    mtx c;memset(c,0,sizeof(c));
    for(int i=1;i<=n;i++)
    for(int j=1;j<=1;j++)
    for(int k=1;k<=n;k++)
    c[i][j]+=a[i][k]*b[k][j];
    memcpy(a,c,sizeof(c));
}
int main()
{
    srand(19260817);
    for(int i=1;i<=500;i++)f[i][1]=1+rand()%1000;
    while(scanf("%d",&n)!=EOF)
    {
        for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
        read(a[i][j]);
        for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
        read(b[i][j]);
        for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
        read(c[i][j]);
        mul(b,f);mul(c,f);mul(a,b);
        int flag=0;
        for(int i=1;i<=n;i++)
        if(a[i][1]!=c[i][1])
        {
            flag=1;
            break;
        }
        printf("%s\n",flag?"No":"Yes");
    }
    return 0;
}
View Code

 

以上是关于bzoj2396: 神奇的矩阵(矩阵乘法+随机化)的主要内容,如果未能解决你的问题,请参考以下文章

bzoj2396神奇的矩阵 随机化

bzoj 2875 [Noi2012]随机数生成器 矩阵乘法

P1224 [NOI2013] 向量内积(矩阵乘法&随机化)

bzoj1778[Usaco2010 Hol]Dotp 驱逐猪猡 矩阵乘法+概率dp+高斯消元

BZOJ 2179 FFT快速傅立叶 ——FFT

Floyd矩阵乘法BZOJ1706- [usaco2007 Nov]relays 奶牛接力跑