forked from marioyc/Online-Judge-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path3656 - Bit Magic.cpp
128 lines (104 loc) · 3.3 KB
/
3656 - Bit Magic.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#include <cstdio>
#include <cstring>
#include <vector>
#include <stack>
using namespace std;
#define MAXN 500
vector<int> L[2 * MAXN];
stack<int> S;
int low[2 * MAXN],curh;
bool in_stack[2 * MAXN];
int cont_scc,id_scc[2 * MAXN];
void tarjan(int cur){
S.push(cur);
in_stack[cur] = true;
low[cur] = ++curh;
for(int i = L[cur].size() - 1,to;i >= 0;--i){
to = L[cur][i];
if(low[to] == -1){
tarjan(to);
low[cur] = min(low[cur],low[to]);
}else if(in_stack[to]){
low[cur] = min(low[cur],low[to]);
}
}
if(low[cur] == curh){
int nxt;
do{
nxt = S.top();
S.pop();
in_stack[nxt] = false;
id_scc[nxt] = cont_scc;
}while(nxt != cur);
++cont_scc;
}
--curh;
}
void build_scc(int V){
memset(low,-1,sizeof low);
memset(in_stack,false,sizeof in_stack);
curh = cont_scc = 0;
for(int i = 0;i < V;++i)
if(low[i] == -1)
tarjan(i);
}
int main(){
int N,b[MAXN][MAXN];
while(scanf("%d",&N) == 1){
for(int i = 0;i < N;++i)
for(int j = 0;j < N;++j)
scanf("%d",&b[i][j]);
bool ok = true;
for(int i = 0;i < N;++i){
if(b[i][i] != 0) ok = false;
for(int j = i + 1;j < N;++j)
if(b[i][j] != b[j][i])
ok = false;
}
for(int p = 0;p < 31 && ok;++p){
for(int i = 0;i < 2 * N;++i)
L[i].clear();
for(int i = 0,i2 = 0;i < N;++i,i2 ^= 1){
for(int j = 0,j2 = 0;j < N;++j,j2 ^= 1){
int x = ((b[i][j] >> p) & 1);
if(i == j) ;
else if(i2 == 1 && j2 == 1){
if(x){
L[j + N].push_back(i);
L[i + N].push_back(j);
}else{
L[i].push_back(i + N);
L[j].push_back(j + N);
}
}else if(i2 == 0 && j2 == 0){
if(x){
L[i + N].push_back(i);
L[j + N].push_back(j);
}else{
L[i].push_back(j + N);
L[j].push_back(i + N);
}
}else{
if(x){
L[i].push_back(j + N);
L[j].push_back(i + N);
L[i + N].push_back(j);
L[j + N].push_back(i);
}else{
L[i].push_back(j);
L[j].push_back(i);
L[i + N].push_back(j + N);
L[j + N].push_back(i + N);
}
}
}
}
build_scc(2 * N);
for(int i = 0;i < N;++i)
if(id_scc[i] == id_scc[i + N])
ok = false;
}
puts(ok? "YES" : "NO");
}
return 0;
}