Day 6 & 7

This commit is contained in:
2024-12-07 14:55:58 +00:00
parent 63d04e6c3c
commit 6c210fd0be
4 changed files with 248 additions and 0 deletions

42
2024/05/index2.ts Normal file
View File

@@ -0,0 +1,42 @@
const fs = require('fs');
const input = fs.readFileSync(__dirname + '/input.txt', 'utf8');
const rules: Array<[number, number]> = [];
const updates: Array<Array<number>> = [];
let rulesSection = true;
input.split("\n").forEach((line: string) => {
if (!line) {
rulesSection = false;
return;
}
if (rulesSection) {
rules.push(line.split('|').map((s) => parseInt(s)) as [number, number]);
} else {
updates.push(line.split(',').map((s) => parseInt(s)));
}
});
let result = 0;
updates.forEach((update) => {
let newUpdate: Array<number> = [];
for (let page of update) {
const relevantRules = rules.filter((rule) => rule[0] === page || rule[1] === page);
let i = 0;
for (; i < newUpdate.length; i++) {
const otherPage = newUpdate[i];
const rule = relevantRules.find((rule) => rule[0] === otherPage || rule[1] === otherPage);
if (rule && rule[0] === page) {
break;
}
}
newUpdate = [...newUpdate.slice(0, i), page, ...newUpdate.slice(i)]
}
if (update.join(',') !== newUpdate.join(',')) {
result += newUpdate[(newUpdate.length - 1) / 2];
}
});
console.log(result);