AdventOfCode/2024/24/solution.py

89 lines
2.6 KiB
Python
Raw Normal View History

2024-12-24 09:30:21 +01:00
#!/bin/python3
import sys,time,re
from pprint import pprint
sys.path.insert(0, '../../')
from fred import list2int,get_re,nprint,lprint,loadFile,dprint
start_time = time.time()
input_f = 'input'
def loadGates(input_f):
gates = {}
instructions = []
with open(input_f) as file:
for line in file:
if ':' in line:
tmp = line.split(': ')
gates[tmp[0]] = int(tmp[1])
if '->' in line:
tmp = line.replace('-> ','').rstrip().split(' ')
instructions.append(tmp)
return gates, instructions
2024-12-24 09:34:08 +01:00
def returnLogic(x,logic,y,z,gates):
# `AND` gates output `1` if *both* inputs are `1`; if either input is `0`, these gates output `0`.
if logic == 'AND':
return 1 if gates[x] and gates[y] else 0
# `OR` gates output `1` if *one or both* inputs is `1`; if both inputs are `0`, these gates output `0`.
if logic == 'OR':
return 1 if gates[x] or gates[y] else 0
# `XOR` gates output `1` if the inputs are *different*; if the inputs are the same, these gates output `0`.
if logic == 'XOR':
return 1 if gates[x] != gates[y] else 0
2024-12-24 09:30:21 +01:00
#########################################
# #
# Part 1 #
# #
#########################################
def part1():
wait_for = []
2024-12-24 09:47:23 +01:00
gates, instructions = loadGates(input_f)
while instructions or wait_for:
if len(instructions) > 0:
inst = instructions.pop(0)
x,logic,y,z = inst
2024-12-24 09:30:21 +01:00
if x not in gates or y not in gates:
wait_for.append(inst)
continue
for wdx, w in enumerate(wait_for):
x,logic,y,z = w
if x in gates and y in gates:
2024-12-24 09:34:08 +01:00
gates[z] = returnLogic(x,logic,y,z,gates)
2024-12-24 09:30:21 +01:00
wait_for.pop(wdx)
x,logic,y,z = inst
2024-12-24 09:34:08 +01:00
gates[z] = returnLogic(x,logic,y,z,gates)
2024-12-24 09:30:21 +01:00
result = ''
countZ = 0
for g in gates.keys():
if g[0] == 'z':
countZ += 1
for i in range(countZ-1,-1,-1):
2024-12-24 09:47:23 +01:00
result += str(gates[f"z{i:02}"])
2024-12-24 09:30:21 +01:00
return int(result, 2)
start_time = time.time()
print('Part 1:',part1(), '\t\t', round((time.time() - start_time)*1000), 'ms')
#########################################
# #
# Part 2 #
# #
#########################################
def part2():
return
start_time = time.time()
print('Part 2:',part2(), '\t\t', round((time.time() - start_time)*1000), 'ms')