diff options
author | Tomasz Kramkowski <tomasz@kramkow.ski> | 2023-12-09 10:07:25 +0000 |
---|---|---|
committer | Tomasz Kramkowski <tomasz@kramkow.ski> | 2023-12-09 10:07:25 +0000 |
commit | f0e81eadf75658eadbc3ce293ef6743b8fea8bc0 (patch) | |
tree | 83bda38deeaddcf1e06dd28d2e5542c39ea8b1bc | |
parent | 849ee38426c977e0dca8a5f43d5d97641d8a23a8 (diff) | |
download | aoc2023-f0e81eadf75658eadbc3ce293ef6743b8fea8bc0.tar.gz aoc2023-f0e81eadf75658eadbc3ce293ef6743b8fea8bc0.tar.xz aoc2023-f0e81eadf75658eadbc3ce293ef6743b8fea8bc0.zip |
day 9
-rw-r--r-- | 9.py | 22 |
1 files changed, 22 insertions, 0 deletions
@@ -0,0 +1,22 @@ +# pyright: strict +from sys import stdin + + +def predict_next(history: list[int]) -> int: + if all(e == 0 for e in history): + return 0 + return history[-1] + predict_next( + [a - b for a, b in zip(history[1:], history[:-1])] + ) + + +def predict_prev(history: list[int]) -> int: + if all(e == 0 for e in history): + return 0 + return history[0] - predict_prev([a - b for a, b in zip(history[1:], history[:-1])]) + + +histories = [[int(e) for e in l.rstrip().split()] for l in stdin] + +print(sum(predict_next(history) for history in histories)) +print(sum(predict_prev(history) for history in histories)) |