-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday10.ts
78 lines (67 loc) · 1.7 KB
/
day10.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
73
74
75
76
77
78
import type { Day } from './Day.ts';
import type { Pos } from './utils.ts';
import { directNeighbors } from './utils.ts';
export class DayImpl implements Day {
private readonly input: number[][];
constructor(input: string) {
this.input = this.parseInput(input);
}
parseInput(input: string) {
return input
.trim()
.split('\n')
.map((line: string) => {
return line
.split('')
.map(Number);
});
}
partOne() {
const starts = findStart(this.input);
return starts
.map((pos) => {
const trails = findTrails(pos, this.input);
return new Set(trails).size;
})
.reduce((acc, val) => acc + val, 0);
}
partTwo() {
const starts = findStart(this.input);
return starts
.map((pos) => {
const trails = findTrails(pos, this.input);
return trails.length;
})
.reduce((acc, val) => acc + val, 0);
}
}
function findStart(grid: number[][]): Pos[] {
return grid
.flatMap((line, y) => {
if (!line.includes(0)) {
return [];
}
return line.map((value: number, x) => {
return [value, [y, x] as Pos];
});
})
.filter(([value]) => value === 0)
.map(([_, pos]) => pos as Pos);
}
function findTrails(pos: Pos, grid: number[][]) {
const trails = [];
const queue = [pos];
while (queue.length) {
const [cy, cx] = queue.shift()!;
if (grid[cy][cx] === 9) {
trails.push(`${cy},${cx}`);
}
const nextPositions = directNeighbors
.map(([dy, dx]) => [cy + dy, cx + dx] as Pos)
.filter(([y, x]) => {
return grid[y]?.[x] === grid[cy][cx] + 1;
});
queue.push(...nextPositions);
}
return trails;
}