-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathwires2.js
43 lines (35 loc) · 1.11 KB
/
wires2.js
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
const getWirePositions = (wire) => {
const positions = new Map();
const position = { x: 0, y: 0 };
let length = 0;
for (let i = 0; i < wire.length; i++) {
const { direction, distance } = wire[i];
for (let step = 1; step <= distance; step++) {
position.x += direction === 'L' ? -1 : direction === 'R' ? 1 : 0;
position.y += direction === 'U' ? -1 : direction === 'D' ? 1 : 0;
positions.set(`${position.x},${position.y}`, ++length);
}
}
return positions;
};
module.exports = (input) => {
const wires = input
.split('\n')
.map((wire) => {
return wire
.trim()
.split(',')
.map((instruction) => {
return {
direction: instruction[0],
distance: Number(instruction.slice(1)),
};
});
});
const wire1Positions = getWirePositions(wires[0]);
const wire2Positions = [...getWirePositions(wires[1]).entries()];
return wire2Positions
.filter(([position]) => wire1Positions.has(position))
.map(([position, steps]) => wire1Positions.get(position) + steps)
.sort((a, b) => a - b)[0];
};