summaryrefslogtreecommitdiff
path: root/2024/12/python.py
diff options
context:
space:
mode:
authormhsn <mail@mhsn.net>2025-09-12 20:20:58 +0100
committermhsn <mail@mhsn.net>2025-09-12 20:36:09 +0100
commit6b733982f9f240c1c97f1fa705bfbe4cd93c640e (patch)
treedad623203c8bb40f372e0ea14479c2f564efda79 /2024/12/python.py
parent9299c4ef655b88eb8b571864c939c78b27f77723 (diff)
downloadaoc-6b733982f9f240c1c97f1fa705bfbe4cd93c640e.tar.gz
aoc-6b733982f9f240c1c97f1fa705bfbe4cd93c640e.zip
simplify python file structure
Diffstat (limited to '2024/12/python.py')
-rwxr-xr-x2024/12/python.py49
1 files changed, 49 insertions, 0 deletions
diff --git a/2024/12/python.py b/2024/12/python.py
new file mode 100755
index 0000000..81761bc
--- /dev/null
+++ b/2024/12/python.py
@@ -0,0 +1,49 @@
+#!/usr/bin/env python3
+
+from fileinput import input
+
+grid = {
+ complex(idx, idy): c
+ for idy, line in enumerate(input())
+ for idx, c in enumerate(line.strip())
+}
+xmax = int(max(x.real for x in grid.keys()))
+ymax = int(max(x.imag for x in grid.keys()))
+
+seen = set()
+
+silver = 0
+
+for x in range(xmax + 1):
+ for y in range(ymax + 1):
+ c = complex(x, y)
+ if c in seen:
+ continue
+
+ # Flood fill
+ char = grid[c]
+ perimeter = area = 0
+ queue = [c]
+ while queue:
+ curr = queue.pop()
+ if curr in seen:
+ continue
+ seen.add(curr)
+
+ for dir in [1, -1, 1j, -1j]:
+ next_ = curr + dir
+ if (
+ not (0 <= next_.real <= xmax and 0 <= next_.imag <= ymax)
+ or grid[next_] != char
+ ):
+ perimeter += 1
+ continue
+
+ queue.append(next_)
+ area += 1
+ silver += perimeter * area
+
+gold = 0
+
+print("silver:", silver)
+print("gold:", gold)