advent-of-code-2022/day06/index.js

34 lines
758 B
JavaScript
Raw Permalink Normal View History

2022-12-06 16:04:35 +00:00
import { readFileSync } from "fs";
const input = readFileSync("datastream.txt", "utf-8");
2022-12-06 16:14:03 +00:00
function checkForDuplicates(arr, howMany) {
2022-12-06 16:04:35 +00:00
const map = new Map();
arr.forEach(char => {
map.set(char, true);
});
2022-12-06 16:14:03 +00:00
return map.size === howMany;
2022-12-06 16:04:35 +00:00
}
2022-12-06 16:14:03 +00:00
const arr1 = new Array(4).fill('');
const arr2 = new Array(14).fill('');
let i = 1, startOfPacket = 0, startOfMessage = 0;
2022-12-06 16:04:35 +00:00
2022-12-06 16:14:03 +00:00
console.log(arr1)
2022-12-06 16:04:35 +00:00
for(const char of input) {
2022-12-06 16:14:03 +00:00
arr1.shift()
arr1.push(char);
arr2.shift()
arr2.push(char);
2022-12-06 16:04:35 +00:00
2022-12-06 16:14:03 +00:00
if(startOfPacket === 0 && i > 4 && checkForDuplicates(arr1, 4)) startOfPacket = i;
if(startOfMessage === 0 && i > 14 && checkForDuplicates(arr2, 14)) startOfMessage = i;
2022-12-06 16:04:35 +00:00
i++;
}
2022-12-06 16:14:03 +00:00
console.log(startOfPacket, startOfMessage);