神奇的矩阵(bzoj 2396)
2017-03-29 07:17
253 查看
Description
给出三个行数和列数均为N的矩阵A、B、C,判断A*B=C是否成立。Input
题目可能包含若干组数据。对于每组数据,第一行一个数N,接下来给出三个N*N的矩阵,依次为A、B、C三个矩阵。
Output
对于每组数据,若A*B=C成立,则输出Yes,否则No。每个答案占一行。Sample Input
12
2
100
Sample Output
NoHINT
对于90%的数据,N不超过100;对于100%的数据,N不超过1000,矩阵中的数字大于等于0小于1000,数据组数不超过5组。
/* 直接判断是O(n^3)的,显然不行,我们发现,如果A*B=C,那么(A*B)*R=C*R。 可以利用以上结论,设R为一个1*n的随机矩阵,如果(A*B)*R与C*R相等,那么A*B与C大几率相等。 */ #include<cstdio> #include<iostream> #include<cstdlib> #define N 1010 using namespace std; int a ,b ,c ,rnd ,ans1 ,ans2 ,n; void mul(int a ,int b ,int c ){ int tmp ={0}; for(int j=1;j<=n;j++) for(int i=1;i<=n;i++) tmp[j]+=a[i]*b[i][j]; for(int i=1;i<=n;i++) c[i]=tmp[i]; } int main(){ freopen("jh.in","r",stdin); for(int i=1;i<=1000;i++) rnd[i]=rand(); while(scanf("%d",&n)!=EOF){ for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) scanf("%d",&a[i][j]); for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) scanf("%d",&b[i][j]); for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) scanf("%d",&c[i][j]); mul(rnd,a,ans1); mul(ans1,b,ans1); mul(rnd,c,ans2); int flag=0; for(int i=1;i<=n;i++) if(ans1[i]!=ans2[i]) {flag=1;break;} if(!flag) printf("Yes\n"); else printf("No\n"); } return 0; }
相关文章推荐
- 【BZOJ 2396】神奇的矩阵 矩阵+随机
- bzoj2396神奇的矩阵 随机化
- BZOJ2396 神奇的矩阵
- bzoj2396 神奇的矩阵
- BZOJ2396 神奇的矩阵 【随机化 + 矩乘】
- bzoj2396 POJ3318 神奇的矩阵 随机化
- bzoj2396 神奇的矩阵
- [随机化 矩阵乘法] BZOJ 2396 神奇的矩阵 & 51Nod 1140 矩阵相乘结果的判断 & POJ 3318 Matrix Multiplication
- BZOJ[2396]神奇的矩阵 随机化
- [bzoj2396][随机化]神奇的矩阵
- bzoj 2396: 神奇的矩阵 随机化
- [bzoj2396][随机化]神奇的矩阵
- 【BZOJ2396 || POJ3318】神奇的矩阵 || Matrix Multiplication
- BZOJ 1059 矩阵游戏(神奇的二分图匹配)
- 【bzoj2396】神奇的矩阵 随机化
- 2396: 神奇的矩阵
- 【bzoj3790】神奇项链——manacher+贪心
- BZOJ 3562: [SHOI2014]神奇化合物 并查集+dfs
- BZOJ1009 [HNOI2008]GT考试 矩阵
- 【bzoj4443】【[Scoi2015]小凸玩矩阵】二分+二分图最大匹配