2021: d04: ex1: add solution
This commit is contained in:
parent
43a15256b8
commit
1dc647e60b
59
2021/d04/ex1/ex1.py
Executable file
59
2021/d04/ex1/ex1.py
Executable file
|
@ -0,0 +1,59 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
import itertools
|
||||||
|
import sys
|
||||||
|
from typing import List, Tuple
|
||||||
|
|
||||||
|
Board = List[List[int]]
|
||||||
|
|
||||||
|
|
||||||
|
def solve(input: List[str]) -> int:
|
||||||
|
def parse_input() -> Tuple[List[int], List[Board]]:
|
||||||
|
def listify(line: str, delim: str = " ") -> List[int]:
|
||||||
|
return [int(n) for n in line.split(delim) if n != ""]
|
||||||
|
|
||||||
|
draw_order = listify(input[0], delim=",")
|
||||||
|
boards: List[Board] = []
|
||||||
|
for l in input[1:]:
|
||||||
|
if l == "":
|
||||||
|
boards.append([])
|
||||||
|
continue
|
||||||
|
boards[-1].append(listify(l))
|
||||||
|
|
||||||
|
return draw_order, boards
|
||||||
|
|
||||||
|
def bingo(board: Board, draw: List[int]) -> bool:
|
||||||
|
assert len(board) == len(board[0])
|
||||||
|
|
||||||
|
def line(l: int) -> bool:
|
||||||
|
return all(n in draw for n in board[l])
|
||||||
|
|
||||||
|
def row(r: int) -> bool:
|
||||||
|
return all(board[i][r] in draw for i in range(len(board)))
|
||||||
|
|
||||||
|
lines = [line(i) for i in range(len(board))]
|
||||||
|
rows = [row(i) for i in range(len(board[0]))]
|
||||||
|
|
||||||
|
return any(itertools.chain(lines, rows))
|
||||||
|
|
||||||
|
draw_order, boards = parse_input()
|
||||||
|
|
||||||
|
draw = []
|
||||||
|
for d in draw_order:
|
||||||
|
draw.append(d)
|
||||||
|
for b in boards:
|
||||||
|
if not bingo(b, draw):
|
||||||
|
continue
|
||||||
|
return d * sum(n for n in itertools.chain.from_iterable(b) if n not in draw)
|
||||||
|
|
||||||
|
# Sanity check
|
||||||
|
assert False
|
||||||
|
|
||||||
|
|
||||||
|
def main() -> None:
|
||||||
|
input = [line.strip() for line in sys.stdin.readlines()]
|
||||||
|
print(solve(input))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
Loading…
Reference in a new issue