-
Notifications
You must be signed in to change notification settings - Fork 0
/
UvA 11902.cpp
141 lines (94 loc) · 2.06 KB
/
UvA 11902.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
129
130
131
132
133
134
135
136
137
138
139
#include <bits/stdc++.h>
#define pb push_back
#define lp(i,n) for(int i=0;i<n;i++)
#define read_int(i) scanf("%d", &i)
using namespace std;
vector < vector <int> > adj_list;
int reachable[101]; //Checks if node reachable from start node
int visited[101];
int state[101][101];
void start_dfs(int node=0){
reachable[node]=1;
for(int neighbour:adj_list[node]){
if(reachable[neighbour]==0){
start_dfs(neighbour);
}
}
}
void dfs(int node,int dominator){
if(node==dominator) return;
visited[node]=1;
state[dominator][node]=0;
for(int neighbour:adj_list[node])
{
if(visited[neighbour]==0)
{
dfs(neighbour,dominator);
}
}
}
void print_line(int n){
printf("+");
for(int i=0; i<n+n+1-2; i++)
printf("-");
printf("+\n");
}
void print_case(int c){
printf("Case %d:\n", c);
}
void reset_vars(){
for(int i=0; i<101; i++){
reachable[i]=0;
visited[i]=0;
for(int j=0; j<101; j++){
state[i][j]=0;
}
}
}
int main ()
{
// freopen("in.txt", "r", stdin);
// freopen("out.txt", "w", stdout);
int t;
read_int(t);
for(int c=1; c<=t; c++)
{
int n;
read_int(n);
adj_list= vector < vector <int> > (n);
reset_vars();
lp(i,n)
{
lp(j,n)
{
int x;
read_int(x);
if(x==1) adj_list[i].pb(j);
}
}
start_dfs();
lp(dominator,n){
lp(node,n){
if(reachable[node]==1)
state[dominator][node]=1;
}
}
lp(i,n){
memset(visited,0, sizeof visited);
dfs(0,i);
}
print_case(c);
lp(i,n)
{
print_line(n);
cout<<"|";
lp(j,n)
{
state[i][j]==1?cout<<"Y|":cout<<"N|";
}
cout<<endl;
}
print_line(n);
}
return 0;
}