-
Notifications
You must be signed in to change notification settings - Fork 0
/
part1.ts
34 lines (28 loc) · 1011 Bytes
/
part1.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
import * as fs from 'fs';
const input = fs.readFileSync('input', 'utf8').split('\n').map((line => line.split('')));
const startY = input.findIndex(line => line.includes('^'));
const startX = input[startY].indexOf('^');
let current = { x: startX, y: startY, direction: 'up' };
const STEP = {
up: { x: 0, y: -1, turnDirection: 'right' },
down: { x: 0, y: 1, turnDirection: 'left' },
left: { x: -1, y: 0, turnDirection: 'up' },
right: { x: 1, y: 0, turnDirection: 'down' },
};
input[current.y][current.x] = '.';
const visited = new Set<string>();
while (input[current.y]?.[current.x]) {
const next = { ...current };
while (input[next.y]?.[next.x] === '.') {
visited.add(`${next.x},${next.y}`);
next.x += STEP[current.direction].x;
next.y += STEP[current.direction].y;
}
if (input[next.y]?.[next.x] === '#') {
next.x -= STEP[current.direction].x;
next.y -= STEP[current.direction].y;
next.direction = STEP[current.direction].turnDirection;
}
current = next;
}
console.log(visited.size);