Clean 2024 day 10.

This commit is contained in:
Mikael CAPELLE 2024-12-10 08:46:44 +01:00
parent 4367a5183a
commit 3c544c559b

View File

@ -1,3 +1,4 @@
import itertools as it
from typing import Any, Iterator from typing import Any, Iterator
from ..base import BaseSolver from ..base import BaseSolver
@ -7,40 +8,28 @@ def process(
grid: list[list[int]], current: tuple[int, int] grid: list[list[int]], current: tuple[int, int]
) -> set[tuple[tuple[int, int], ...]]: ) -> set[tuple[tuple[int, int], ...]]:
row, col = current row, col = current
value = grid[row][col] + 1
if grid[row][col] == 9: if grid[row][col] == 9:
return {((row, col),)} return {((row, col),)}
result: set[tuple[tuple[int, int], ...]] = set() return {
((row, col),) + path
for di, dj in ((-1, 0), (0, 1), (1, 0), (0, -1)): for i, j in ((row - 1, col), (row, col + 1), (row + 1, col), (row, col - 1))
i, j = row + di, col + dj if 0 <= i < len(grid) and 0 <= j < len(grid[i]) and grid[i][j] == value
for path in process(grid, (i, j))
if i < 0 or i >= len(grid) or j < 0 or j >= len(grid[row]): }
continue
if grid[i][j] != grid[row][col] + 1:
continue
for path in process(grid, (i, j)):
result.add(((row, col),) + path)
return result
class Solver(BaseSolver): class Solver(BaseSolver):
def solve(self, input: str) -> Iterator[Any]: def solve(self, input: str) -> Iterator[Any]:
grid = [[int(col) for col in row] for row in input.splitlines()] grid = [[int(col) for col in row] for row in input.splitlines()]
n_rows, n_cols = len(grid), len(grid[0])
heads = [ paths = {
(i, j) for i in range(n_rows) for j in range(n_cols) if grid[i][j] == 0 (i, j): process(grid, (i, j))
] for i, j in it.product(range(len(grid)), range(len(grid[0])))
if grid[i][j] == 0
}
# for head in heads: yield sum(len({path[-1] for path in paths[head]}) for head in paths)
# print(head, process(grid, head)) yield sum(len(paths_of) for paths_of in paths.values())
paths = {head: process(grid, head) for head in heads}
yield sum(len({path[-1] for path in paths[head]}) for head in heads)
yield sum(len(paths[head]) for head in heads)