-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathb1707.js
More file actions
53 lines (45 loc) · 1.1 KB
/
b1707.js
File metadata and controls
53 lines (45 loc) · 1.1 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
51
52
53
var fs = require("fs");
var input = fs.readFileSync("/dev/stdin").toString().trim().split("\n");
const inputs = input.slice(1).map((r) => r.split(" ").map(Number));
let i = 0;
while (i < inputs.length) {
const [V, E] = inputs[i++];
const adjs = Array(V + 1)
.fill(0)
.map(() => Array());
const visited = Array(V + 1).fill(false);
const color = Array(V + 1).fill("");
for (let j = i; j < i + E; j++) {
const [s, e] = inputs[j];
adjs[s].push(e);
adjs[e].push(s);
}
function bfs(v) {
const stack = [v];
visited[v] = true;
color[v] = "r";
while (stack.length) {
const curr = stack.shift();
for (const next of adjs[curr]) {
if (color[next] === color[curr]) {
return false;
}
if (visited[next]) continue;
color[next] = color[curr] === "r" ? "b" : "r";
visited[next] = true;
stack.push(next);
}
}
return true;
}
let res;
for (let k = 1; k <= V; k++) {
if (visited[k]) continue;
res = bfs(k);
if (!res) {
break;
}
}
console.log(res ? "YES" : "NO");
i += E;
}