day 4 puzzle 1

This commit is contained in:
Louis Heredero 2024-12-04 09:44:54 +01:00
parent 66f04ed889
commit 65beed1c51
Signed by: HEL
GPG Key ID: 8D83DE470F8544E7
6 changed files with 70 additions and 1 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 110 KiB

After

Width:  |  Height:  |  Size: 110 KiB

View File

@ -3,4 +3,6 @@
2:
stars: 2
3:
stars: 2
stars: 2
4:
stars: 1

10
res/examples/day4.txt Normal file
View File

@ -0,0 +1,10 @@
MMMSXXMASM
MSAMXMSMSA
AMXSXMAAMM
MSAMASMSMX
XMASAMXAMM
XXAMMXXAMA
SMSMSASXSS
SAXAMASAAA
MAMMMXMMMM
MXMXAXMASX

57
src/day4/puzzle1.typ Normal file
View File

@ -0,0 +1,57 @@
#import "/src/utils.typ": *
#let check-xmas(lines, ox, oy) = {
let w = lines.first().len()
let h = lines.len()
let total = 0
for dy in (-1, 0, 1) {
for dx in (-1, 0, 1) {
if dx == 0 and dy == 0 {
continue
}
let buffer = ""
let x = ox
let y = oy
for i in range(4) {
buffer += lines.at(y).at(x)
x += dx
y += dy
if (
not "XMAS".starts-with(buffer) or
x < 0 or x >= w or
y < 0 or y >= h
) {
break
}
}
if buffer == "XMAS" {
total += 1
}
}
}
return total
}
#let solve(input) = {
let lines = input.split("\n")
let w = lines.first().len()
let h = lines.len()
let total = 0
for y in range(h) {
for x in range(h) {
if lines.at(y).at(x) == "X" {
total += check-xmas(lines, x, y)
}
}
}
return total
}
#show-puzzle(
4, 1,
solve,
example: 18
)

0
src/day4/puzzle2.typ Normal file
View File

Binary file not shown.