advent-of-code-2024/day5/part1.ts

28 lines
944 B
TypeScript
Raw Permalink Normal View History

2024-12-03 21:42:57 -07:00
export async function solve() {
2024-12-03 21:42:57 -07:00
const [rules, pages] = await Deno.readTextFile(import.meta.dirname + "/input.txt")
2024-12-03 21:42:57 -07:00
.then(i => i
.split("\n\n")
).then(([rules, pages]) => [
rules.split("\n").map(e => e.split("|") as [string, string]),
pages.split("\n").map(e => e.split(","))
] as const);
let sum = 0;
for (const pageGroup of pages) {
let valid = true;
for (let i = 1; i < pageGroup.length; i++) {
const matchingRules = rules.filter(([before, _]) => before == pageGroup[i]).filter(
([before, _]) => before == pageGroup[i]
).map(([_, after]) => after);
if (matchingRules.some(after => pageGroup.slice(0, i).includes(after))) {
valid = false;
break
}
}
if (valid) sum += +pageGroup[Math.floor(pageGroup.length / 2)];
}
return sum
}