-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathpart_1.js
31 lines (24 loc) · 1.17 KB
/
part_1.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
import fs from "node:fs";
import path from "node:path";
import { performance } from "node:perf_hooks";
import { fileURLToPath } from "url";
const __dirname = path.dirname(fileURLToPath(import.meta.url));
// ========================= //
// = Copyright (c) NullDev = //
// ========================= //
const CONTENT_READ = String(fs.readFileSync(path.join(__dirname, "input.txt"))).trimEnd().split("\n\n");
const pStart = performance.now();
const RES = Object.values(CONTENT_READ.reduce((prev, tile) => {
const grid = tile.split("\n").slice(1).map(w => w.split(""));
[grid[0], grid.map(r => r[0]), grid.map(r => r[grid.length - 1]), grid[grid.length - 1]].forEach(b => {
const t = [b, ([...b].reverse())].sort()[0]; // @ts-ignore
prev[t] = typeof(prev[t]) === "undefined" ? [].concat(Number(tile.match(/^Tile (\d+):\n/)[1])) : prev[t].concat(Number(tile.match(/^Tile (\d+):\n/)[1]));
});
return prev;
}, {})).filter(ids => ids.length === 1) // @ts-ignore
.flat()
.filter((id, index, ids) => ids.indexOf(id) !== index)
.reduce((a, b) => a * b, 1);
const pEnd = performance.now();
console.log("PRODUCT OF IDS: " + RES);
console.log(pEnd - pStart);