diff options
| -rwxr-xr-x | 2024/24/puzzle-1.py | 46 | 
1 files changed, 46 insertions, 0 deletions
| diff --git a/2024/24/puzzle-1.py b/2024/24/puzzle-1.py new file mode 100755 index 0000000..d2d27ca --- /dev/null +++ b/2024/24/puzzle-1.py @@ -0,0 +1,46 @@ +#!/usr/bin/python3 + +import collections +from typing import Deque + + +def main() -> None: +	with open("input", "r") as f: +		head, tail = [s.split("\n") for s in f.read().split("\n\n")] +	wires: dict[str, int] = {} +	for line in head: +		wire, val = line.split(": ") +		wires[wire] = int(val) +	todo: Deque[list[str]] = collections.deque() +	for line in tail: +		parts = line.split() +		parts.pop(3)            # Pop ‘->’ +		todo.append(parts) + +	while todo: +		eqn = todo[0] +		if not (eqn[0] in wires and eqn[2] in wires): +			todo.rotate(-1) +			continue +		else: +			todo.popleft() +		lhs = wires[eqn[0]] +		rhs = wires[eqn[2]] +		match eqn[1]: +			case 'AND': +				x = lhs & rhs +			case 'OR': +				x = lhs | rhs +			case 'XOR': +				x = lhs ^ rhs +		wires[eqn[3]] = x + +	n = 0 +	ends = ((k, v) for k, v in wires.items() if k[0] == 'z') +	for k, v in sorted(ends, reverse=True): +		n = n<<1 | v +	print(n) + + +if __name__ == "__main__": +	main()
\ No newline at end of file |