advent_of_code/2023/day19/part_two.py

105 lines
2.5 KiB
Python

from dis import Instruction
import re
from tabnanny import check
import numpy as np
import copy
file = open('input.txt', 'r')
# file = open('test.txt', 'r')
content = file.read()
# lines = content.splitlines()
paragraphs = content.split("\n\n")
sum = 0
flows = {}
print(paragraphs[0].split("\n")[0].split('{')[1].strip("}"))
for workflow in paragraphs[0].split("\n"):
sub_workflow = workflow.split('{')
name = sub_workflow[0]
instructions = sub_workflow[1].strip("}").split(",")
# print(instructions)
inst_list = []
for a in instructions:
if_stat = a.split(":")
logic = []
for ch in ["<", ">"]:
if ch in if_stat[0]:
temp = if_stat[0].split(ch)
logic = [temp[0], ch, int(temp[1])]
break
# inst
inst_list.append(logic+[if_stat[-1]])
print(inst_list)
flows[name] = inst_list
vals = []
for val in paragraphs[1].split("\n"):
current_val = {}
for i in val.strip("{}").split(","):
x = i.split("=")
print(x)
current_val[x[0]] = int(x[1])
vals.append(current_val)
print(vals)
print(flows)
sum = 0
Possible = {
"x": {"min": 1, "max":4000},
"m": {"min": 1, "max":4000},
"a": {"min": 1, "max":4000},
"s": {"min": 1, "max":4000},
"keys": [],
}
total_list = []
def f(key, possible_in):
possible = copy.deepcopy(possible_in)
possible["keys"].append(key)
if key == "A":
total_list.append(possible)
elif key != "R":
for inst in flows[key]:
new_possible = copy.deepcopy(possible)
if len(inst) == 1:
f(inst[-1], possible)
break
else:
if inst[1] == "<":
new_possible[inst[0]]["max"] = min(inst[2]-1, new_possible[inst[0]]["max"])
f(inst[-1], new_possible)
possible[inst[0]]["min"] = max(inst[2], possible[inst[0]]["min"])
elif inst[1] == ">":
new_possible[inst[0]]["min"] = max(inst[2]+1, new_possible[inst[0]]["min"])
f(inst[-1], new_possible)
possible[inst[0]]["max"] = min(inst[2], possible[inst[0]]["max"])
else:
print("PANIC!")
key = "in"
f(key, Possible)
print(total_list)
for entry in total_list:
temp = 1
for ch in ['x', 'm', 'a', 's']:
temp *= max(0, entry[ch]["max"]-entry[ch]["min"]+1)
sum += temp
print(sum)
file.close()