-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path1217D.cpp
More file actions
50 lines (43 loc) · 1.41 KB
/
1217D.cpp
File metadata and controls
50 lines (43 loc) · 1.41 KB
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
#include <bits/stdc++.h>
using namespace std;
typedef vector<int> vi;
typedef vector<vector<int>> vvi;
typedef pair<int, int> pii;
auto pair_hash = [](const auto &p) { return p.first ^ p.second << 16; };
typedef unordered_map<pair<int, int>, int, decltype(pair_hash)> umpiii;
void dfs_v(int i, int prev, vi &result, vvi &g, umpiii &order, vi &visited, int &color) {
if(visited[i] == 1) color = result[order[{prev, i}]] = 2;
else if(prev != -1 && visited[i] == 2) result[order[{prev, i}]] = 1;
else {
visited[i] = 1;
if(prev != -1) result[order[{prev, i}]] = 1;
for(auto &next : g[i]) {
dfs_v(next, i, result, g, order, visited, color);
}
visited[i] = 2;
}
}
void dfs(vi &result, vvi &g, umpiii &order, int &color) {
vi visited(g.size(), 0);
for(int i = 0; i < g.size(); i++) {
if(!visited[i])
dfs_v(i, -1, result, g, order, visited, color);
}
}
int main() {
int n, m; cin >> n >> m;
vector<vector<int>> g(n);
umpiii order(m, pair_hash);
vector<int> result(m);
for(int i = 0, u, v; i < m; i++) {
cin >> u >> v; u--; v--;
g[u].push_back(v);
order[{u, v}] = i;
}
int color = 0;
dfs(result, g, order, color);
if(color) cout << 2 << endl;
else cout << 1 << endl;
for(auto &i : result) cout << i << " ";
cout << endl;
}