kovanice.cpp: In function 'int main()':
kovanice.cpp:56:33: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
56 | #define fri(x) for(int i = 0; i < x; ++i)
| ~~^~~~~~~~~
57 | #define frj(x) for(int j = 0; j < x; ++j)
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
58 | #define frp(x) for(int p = 0; p < x; ++p)
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
59 | #define frr(a, b) for(int i = a; i < b; ++i)
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
60 | #define frrj(a, b) for(int j = a; j < b; ++j)
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
61 | #define fra(x) for(int i = 0; i < x; ++i) cin >> a[i];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
62 | #define frb(x) for(int i = 0; i < x; ++i) cin >> b[i];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
63 | #define frs(x) for(auto it = x.begin(); it != x.end(); ++it)
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
64 | #define fr(x) for(auto it : x) //el
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
65 | #define fastio ios_base::sync_with_stdio(false); cin.tie(0);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
66 | #define dbg(x) cerr << #x << ": " << x << endl;
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
67 | #define ce(x) cout << x << endl;
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
68 | #define uniq(x) x.resize(unique(all(x)) - x.begin()); //make all one after sorting
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
69 | #define blt __builtin_popcount
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
70 | /////////////////////print array, vector, deque, set, multiset, pair, map /////////////////////
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
71 | void print(long long t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
72 | void print(int t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
73 | void print(string t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
74 | void print(char t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
75 | void print(double t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
76 | void print(long double t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
77 | void print(unsigned long long t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
78 | template <class T, class V> void print(pair <T, V> p) {cerr << "{"; print(p.first); cerr << ","; print(p.second); cerr << "}";}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
79 | template <class T, class V> void print(T v[],V n) {cerr << "["; for(int i = 0; i < n; i++) {print(v[i]); cerr << " "; } cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
80 | template <class T> void print(vector <T> v) {cerr << "[ "; for (T i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
81 | template <class T> void print(set <T> v) {cerr << "[ "; for (T i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
82 | template <class T> void print(multiset <T> v) {cerr << "[ "; for (T i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
83 | template <class T> void print(stack <T> v) {cerr << "[ "; stack<T> s = v; while(s.size()) {T i = s.top(); print(i); s.pop(); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
84 | template <class T> void print(queue <T> v) {cerr << "[ "; queue<T> s = v; while(s.size()) {T i = s.front(); print(i); s.pop(); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
85 | template <class T> void print(deque <T> v) {cerr << "[ "; deque<T> s = v; while(s.size()) {T i = s.front(); print(i); s.pop_front(); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
86 | template <class T, class V> void print(map <T, V> v) {cerr << "[ "; for (auto i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
87 | template <class T, class V> void print(unordered_map <T, V> v) {cerr << "[ "; for (auto i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
88 | /////////////////////code/////////////////////
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
89 | vi eq[1000005], g[1000005], gr[1000005], topsort;
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
90 | int d[1000005], ans[1000005], in[1000005], out[1000005];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
91 | int color, comp[1000005], answ[1000005];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
92 | void dfs(int v) {
| ~~~~~~~~~~~~~~~~~
93 | comp[v] = 1;
| ~~~~~~~~~~~~
94 | for(int u : g[v])
| ~~~~~~~~~~~~~~~~~
95 | if(!comp[u])
| ~~~~~~~~~~~~
96 | dfs(u);
| ~~~~~~~
97 | topsort.pb(v);
| ~~~~~~~~~~~~~~
98 | }
| ~
99 | void dfs1(int v) {
| ~~~~~~~~~~~~~~~~~~
100 | comp[v] = 1;
| ~~~~~~~~~~~~
101 | for(int u : gr[v]) {
| ~~~~~~~~~~~~~~~~~~~~
102 | if(!comp[u]) dfs1(u);
| ~~~~~~~~~~~~~~~~~~~~~
103 | in[v] = max(in[v], in[u] + 1);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
104 | }
| ~
105 | for(int u : eq[v]) {
| ~~~~~~~~~~~~~~~~~~~~
106 | if(!comp[u]) dfs1(u);
| ~~~~~~~~~~~~~~~~~~~~~
107 | in[v] = max(in[v], in[u]);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~
108 | in[u] = in[v];
| ~~~~~~~~~~~~~~
109 | }
| ~
110 | }
| ~
111 | void dfs2(int v) {
| ~~~~~~~~~~~~~~~~~~
112 | comp[v] = 1;
| ~~~~~~~~~~~~
113 | for(int u : g[v]) {
| ~~~~~~~~~~~~~~~~~~~
114 | if(!comp[u]) dfs2(u);
| ~~~~~~~~~~~~~~~~~~~~~
115 | out[v] = max(out[v], out[u] + 1);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
116 | }
| ~
117 | for(int u : eq[v]) {
| ~~~~~~~~~~~~~~~~~~~~
118 | if(!comp[u]) dfs2(u);
| ~~~~~~~~~~~~~~~~~~~~~
119 | out[v] = max(out[v], out[u]);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
120 | out[u] = out[v];
| ~~~~~~~~~~~~~~~~
121 | }
| ~
122 | }
| ~
123 | void dfscomp(int v) {
| ~~~~~~~~~~~~~~~~~~~~~
124 | comp[v] = color;
| ~~~~~~~~~~~~~~~~
125 | if(ans[v]) answ[color] = ans[v];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
126 | for(int u : eq[v])
| ~~~~~~~~~~~~~~~~~~
127 | if(!comp[u])
| ~~~~~~~~~~~~
128 | dfscomp(u);
| ~~~~~~~~~~~
129 | }
| ~
130 | int main() {
| ~~~~~~~~~~~~
131 | fastio;
| ~~~~~~~
132 | int n, m, q; cin >> n >> m >> q; //n->tesakner, m->qanak
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
133 | string s;
| ~~~~~~~~~
134 | fri(q) {
| ~~~~~~~~
135 | cin >> s;
| ~~~~~~~~~
136 | int id, x = 0, y = 0;
| ~~~~~~~~~~~~~~~~~~~~~
137 | fri(s.size()) {
| ~~~~~~~~~~~~
kovanice.cpp:137:3: note: in expansion of macro 'fri'
137 | fri(s.size()) {
| ^~~
kovanice.cpp:59:36: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
59 | #define frr(a, b) for(int i = a; i < b; ++i)
| ~~^~~~~~~~~
60 | #define frrj(a, b) for(int j = a; j < b; ++j)
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
61 | #define fra(x) for(int i = 0; i < x; ++i) cin >> a[i];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
62 | #define frb(x) for(int i = 0; i < x; ++i) cin >> b[i];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
63 | #define frs(x) for(auto it = x.begin(); it != x.end(); ++it)
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
64 | #define fr(x) for(auto it : x) //el
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
65 | #define fastio ios_base::sync_with_stdio(false); cin.tie(0);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
66 | #define dbg(x) cerr << #x << ": " << x << endl;
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
67 | #define ce(x) cout << x << endl;
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
68 | #define uniq(x) x.resize(unique(all(x)) - x.begin()); //make all one after sorting
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
69 | #define blt __builtin_popcount
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
70 | /////////////////////print array, vector, deque, set, multiset, pair, map /////////////////////
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
71 | void print(long long t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
72 | void print(int t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
73 | void print(string t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
74 | void print(char t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
75 | void print(double t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
76 | void print(long double t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
77 | void print(unsigned long long t) {cerr << t;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
78 | template <class T, class V> void print(pair <T, V> p) {cerr << "{"; print(p.first); cerr << ","; print(p.second); cerr << "}";}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
79 | template <class T, class V> void print(T v[],V n) {cerr << "["; for(int i = 0; i < n; i++) {print(v[i]); cerr << " "; } cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
80 | template <class T> void print(vector <T> v) {cerr << "[ "; for (T i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
81 | template <class T> void print(set <T> v) {cerr << "[ "; for (T i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
82 | template <class T> void print(multiset <T> v) {cerr << "[ "; for (T i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
83 | template <class T> void print(stack <T> v) {cerr << "[ "; stack<T> s = v; while(s.size()) {T i = s.top(); print(i); s.pop(); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
84 | template <class T> void print(queue <T> v) {cerr << "[ "; queue<T> s = v; while(s.size()) {T i = s.front(); print(i); s.pop(); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
85 | template <class T> void print(deque <T> v) {cerr << "[ "; deque<T> s = v; while(s.size()) {T i = s.front(); print(i); s.pop_front(); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
86 | template <class T, class V> void print(map <T, V> v) {cerr << "[ "; for (auto i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
87 | template <class T, class V> void print(unordered_map <T, V> v) {cerr << "[ "; for (auto i : v) {print(i); cerr << " ";} cerr << "]"; cout << endl;}
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
88 | /////////////////////code/////////////////////
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
89 | vi eq[1000005], g[1000005], gr[1000005], topsort;
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
90 | int d[1000005], ans[1000005], in[1000005], out[1000005];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
91 | int color, comp[1000005], answ[1000005];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
92 | void dfs(int v) {
| ~~~~~~~~~~~~~~~~~
93 | comp[v] = 1;
| ~~~~~~~~~~~~
94 | for(int u : g[v])
| ~~~~~~~~~~~~~~~~~
95 | if(!comp[u])
| ~~~~~~~~~~~~
96 | dfs(u);
| ~~~~~~~
97 | topsort.pb(v);
| ~~~~~~~~~~~~~~
98 | }
| ~
99 | void dfs1(int v) {
| ~~~~~~~~~~~~~~~~~~
100 | comp[v] = 1;
| ~~~~~~~~~~~~
101 | for(int u : gr[v]) {
| ~~~~~~~~~~~~~~~~~~~~
102 | if(!comp[u]) dfs1(u);
| ~~~~~~~~~~~~~~~~~~~~~
103 | in[v] = max(in[v], in[u] + 1);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
104 | }
| ~
105 | for(int u : eq[v]) {
| ~~~~~~~~~~~~~~~~~~~~
106 | if(!comp[u]) dfs1(u);
| ~~~~~~~~~~~~~~~~~~~~~
107 | in[v] = max(in[v], in[u]);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~
108 | in[u] = in[v];
| ~~~~~~~~~~~~~~
109 | }
| ~
110 | }
| ~
111 | void dfs2(int v) {
| ~~~~~~~~~~~~~~~~~~
112 | comp[v] = 1;
| ~~~~~~~~~~~~
113 | for(int u : g[v]) {
| ~~~~~~~~~~~~~~~~~~~
114 | if(!comp[u]) dfs2(u);
| ~~~~~~~~~~~~~~~~~~~~~
115 | out[v] = max(out[v], out[u] + 1);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
116 | }
| ~
117 | for(int u : eq[v]) {
| ~~~~~~~~~~~~~~~~~~~~
118 | if(!comp[u]) dfs2(u);
| ~~~~~~~~~~~~~~~~~~~~~
119 | out[v] = max(out[v], out[u]);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
120 | out[u] = out[v];
| ~~~~~~~~~~~~~~~~
121 | }
| ~
122 | }
| ~
123 | void dfscomp(int v) {
| ~~~~~~~~~~~~~~~~~~~~~
124 | comp[v] = color;
| ~~~~~~~~~~~~~~~~
125 | if(ans[v]) answ[color] = ans[v];
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
126 | for(int u : eq[v])
| ~~~~~~~~~~~~~~~~~~
127 | if(!comp[u])
| ~~~~~~~~~~~~
128 | dfscomp(u);
| ~~~~~~~~~~~
129 | }
| ~
130 | int main() {
| ~~~~~~~~~~~~
131 | fastio;
| ~~~~~~~
132 | int n, m, q; cin >> n >> m >> q; //n->tesakner, m->qanak
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
133 | string s;
| ~~~~~~~~~
134 | fri(q) {
| ~~~~~~~~
135 | cin >> s;
| ~~~~~~~~~
136 | int id, x = 0, y = 0;
| ~~~~~~~~~~~~~~~~~~~~~
137 | fri(s.size()) {
| ~~~~~~~~~~~~~~~
138 | if(s[i] == '=' || s[i] == '<' || s[i] == '>') {
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
139 | id = i+1;
| ~~~~~~~~~
140 | break;
| ~~~~~~
141 | }
| ~
142 | x *= 10; x += s[i] - '0';
| ~~~~~~~~~~~~~~~~~~~~~~~~~
143 | }
| ~
144 | frr(id, s.size()) {
| ~~~~~~~~~~~~~~~~
kovanice.cpp:144:3: note: in expansion of macro 'frr'
144 | frr(id, s.size()) {
| ^~~
kovanice.cpp:148:10: warning: 'id' may be used uninitialized in this function [-Wmaybe-uninitialized]
148 | if(s[id-1] == '=') {
| ~~^~