2024-12-03 21:42:57 -07:00
|
|
|
export async function solve() {
|
2024-12-03 21:42:57 -07:00
|
|
|
const grid = await Deno.readTextFile(import.meta.dirname + "/input.txt").then(i => i.split("\n").map(l => l.split("")));
|
2024-12-03 21:42:57 -07:00
|
|
|
let sum = 0;
|
|
|
|
|
|
|
|
for (const [y, line] of grid.map((e, i) => [i, e] as const)) {
|
|
|
|
for (let x = 0; x < line.length; x++) {
|
|
|
|
if (
|
|
|
|
// Check diagonal \ forwards & backwards
|
|
|
|
["MAS", "SAM"].includes(grid.slice(y, y + 3).map((l, i) => l[x + i]).join(""))
|
|
|
|
// Check diagonal / forwards & backwards
|
|
|
|
&& ["MAS", "SAM"].includes(grid.slice(y, y + 3).map((l, i) => l[x + 2 - i]).join(""))
|
|
|
|
) sum++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return sum
|
|
|
|
}
|