-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path16-2.ts
72 lines (56 loc) · 1.85 KB
/
16-2.ts
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
export default function main(input: string): string {
const grid = input.split('\n').map((l) => l.split(''));
// key = position id (pos[0] * grid.length + pos[1])
// value = array of directions
const visited = new Map<number, [number, number][]>();
let maxVisited = 0;
for (const start of getAllPossibleStarts(grid)) {
recurse(start.pos, start.dir);
if (visited.size > maxVisited) {
maxVisited = visited.size;
}
visited.clear();
}
return maxVisited.toString();
function recurse(pos: [number, number], dir: [number, number]) {
const char = grid[pos[0]]?.[pos[1]];
if (char === undefined) return;
const posId = pos[0] * grid.length + pos[1];
if (visited.has(posId)) {
if (visited.get(posId)!.some((d) => d[0] === dir[0] && d[1] === dir[1])) {
// already been here
return;
} else {
visited.get(posId)!.push([...dir]);
}
} else {
visited.set(posId, [[...dir]]);
}
if (char === '\\') {
[dir[0], dir[1]] = [dir[1], dir[0]];
} else if (char === '/') {
[dir[0], dir[1]] = [-dir[1], -dir[0]];
} else if (char === '|' && dir[0] === 0) {
recurse([pos[0] - 1, pos[1]], [-1, 0]);
dir = [1, 0];
} else if (char === '-' && dir[1] === 0) {
recurse([pos[0], pos[1] - 1], [0, -1]);
dir = [0, 1];
}
recurse([pos[0] + dir[0], pos[1] + dir[1]], [...dir]);
}
}
function getAllPossibleStarts(grid: string[][]) {
const size = grid.length;
if (size !== grid[0].length) throw new Error('assert height = width');
const starts: { pos: [number, number]; dir: [number, number] }[] = [];
for (let i = 0; i < size; i++) {
starts.push(
{ pos: [0, i], dir: [1, 0] },
{ pos: [i, 0], dir: [0, 1] },
{ pos: [size - 1, i], dir: [-1, 0] },
{ pos: [i, size - 1], dir: [0, -1] }
);
}
return starts;
}