diff options
Diffstat (limited to 'day-8/script.ts')
-rw-r--r-- | day-8/script.ts | 49 |
1 files changed, 32 insertions, 17 deletions
diff --git a/day-8/script.ts b/day-8/script.ts index 71849c7..87e33cd 100644 --- a/day-8/script.ts +++ b/day-8/script.ts @@ -1,5 +1,13 @@ import fs from "fs"; +function gcd(a: number, b: number) { + return !b ? a : gcd(b, a % b); +} + +function lcm(a: number, b: number) { + return (a * b) / gcd(a, b); +} + const [directions, _, ...lines] = fs .readFileSync("./input.txt") .toString() @@ -17,26 +25,33 @@ const nodes = lines }; }) .map((node, index, nodes) => ({ + name: node.node, node: index, left: nodes.findIndex((n) => n.node === node.left), right: nodes.findIndex((n) => n.node === node.right), })); -const targetNumber = lines.findIndex((line) => line.startsWith("ZZZ")); -let currentNumber = lines.findIndex((line) => line.startsWith("AAA")); - -let steps = 0; -while (currentNumber !== targetNumber) { - const direction = ( - { - L: "left", - R: "right", - } as const - )[directions[steps % directions.length]]; - if (!direction) throw new Error("Invalid direction"); - - currentNumber = nodes[currentNumber][direction]; - steps++; -} +const [startingNodes, terminalNodes] = ["A", "Z"].map((char) => + nodes.filter((n) => n.name.endsWith(char)).map((n) => n.node), +); + +const result = startingNodes + .map((node) => { + let steps = 0; + while (!terminalNodes.includes(node)) { + const direction = ( + { + L: "left", + R: "right", + } as const + )[directions[steps % directions.length]]; + if (!direction) throw new Error("Invalid direction"); + + node = nodes[node][direction]; + steps++; + } + return steps; + }) + .reduce((acc, x) => lcm(acc, x), 1); -console.log({ steps }); +console.log({ result }); |