From 1aa61998796394762aa8027412e9c0339949b2a3 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Tue, 8 Dec 2020 08:23:38 +0100 Subject: [PATCH] 2020: d08: ex1: add solution --- 2020/d08/ex1/ex1.py | 51 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100755 2020/d08/ex1/ex1.py diff --git a/2020/d08/ex1/ex1.py b/2020/d08/ex1/ex1.py new file mode 100755 index 0000000..a2394fa --- /dev/null +++ b/2020/d08/ex1/ex1.py @@ -0,0 +1,51 @@ +#!/usr/bin/env python + + +import sys +from typing import List, Tuple + + +def run(code: List[Tuple[str, int]]) -> int: + accumulator = 0 + rip = 0 + + def acc(val: int) -> None: + nonlocal accumulator + nonlocal rip + accumulator += val + rip += 1 + + def nop(val: int) -> None: + nonlocal rip + rip += 1 + + def jmp(val: int) -> None: + nonlocal rip + rip += val + + instrs = { + "acc": acc, + "jmp": jmp, + "nop": nop, + } + seen = set() + + while rip not in seen: + seen |= {rip} + func = instrs[code[rip][0]] + func(code[rip][1]) + + return accumulator + + +def solve(raw: List[str]) -> int: + return run([(line[:3], int(line[3:])) for line in raw]) + + +def main() -> None: + input = [line.strip() for line in sys.stdin.readlines()] + print(solve(input)) + + +if __name__ == "__main__": + main()