2022 - Day 11 part 2 - unfinished
This commit is contained in:
parent
e0e7137a92
commit
f0b6310858
1 changed files with 127 additions and 0 deletions
127
2022/11/11_2.py
Normal file
127
2022/11/11_2.py
Normal file
|
@ -0,0 +1,127 @@
|
|||
#!/usr/bin/env python
|
||||
# 2022 - Advent Of Code 11 part 2
|
||||
# since it's not finished at all, disable pylint
|
||||
# pylint: skip-file
|
||||
|
||||
class Monkey:
|
||||
def __init__(self, sitems, op, op2, divisible, ta, tf):
|
||||
self.sitems = sitems
|
||||
self.items = []
|
||||
self.operation = op
|
||||
self.operand = op2
|
||||
self.divisible = divisible
|
||||
self.action_true = ta
|
||||
self.action_false = tf
|
||||
self.activity = 0
|
||||
|
||||
def print(self):
|
||||
print(f'start items: {self.sitems}')
|
||||
print(f'factored items: {self.items}')
|
||||
print(f'operation: {self.operation} {self.operand}')
|
||||
print(f'divisible: {self.divisible}')
|
||||
print(f'true: {self.action_true}')
|
||||
print(f'false: {self.action_false}')
|
||||
# print(f'{}')
|
||||
print()
|
||||
|
||||
def operate(self, item):
|
||||
if self.operation == '+':
|
||||
pass
|
||||
if self.operation == '*':
|
||||
if self.operand != 'old':
|
||||
item.update([self.operand]) # |=
|
||||
|
||||
def turn(self, other_monkeys):
|
||||
for item in self.items:
|
||||
self.activity += 1
|
||||
self.operate(item)
|
||||
if self.divisible in item:
|
||||
print(f'throwing worry level {item} to monkey {self.action_true}')
|
||||
other_monkeys[self.action_true].throw_item(item)
|
||||
else:
|
||||
print(f'throwing worry level {item} to monkey {self.action_false}')
|
||||
other_monkeys[self.action_false].throw_item(item)
|
||||
self.items = []
|
||||
|
||||
def throw_item(self, item):
|
||||
self.items.append(item)
|
||||
|
||||
|
||||
def prime_factors(n):
|
||||
i = 2
|
||||
factors = []
|
||||
while i * i <= n:
|
||||
if n % i:
|
||||
i += 1
|
||||
else:
|
||||
n //= i
|
||||
factors.append(i)
|
||||
if n > 1:
|
||||
factors.append(n)
|
||||
return factors
|
||||
|
||||
|
||||
def parse_file(file):
|
||||
m_list = []
|
||||
with open(file, encoding="utf-8") as f:
|
||||
line = f.readline() # monkey
|
||||
while line:
|
||||
line = f.readline().strip()
|
||||
item_list = line.split('Starting items:')[1]
|
||||
items = [int(i) for i in item_list.split(',')]
|
||||
# print(items)
|
||||
line = f.readline().strip()
|
||||
oper = line.split('Operation: new = old ')[1]
|
||||
operation = oper[0]
|
||||
# print(oper)
|
||||
if oper[1:] == ' old':
|
||||
operand = 'old'
|
||||
else:
|
||||
operand = int(oper[1:])
|
||||
|
||||
line = f.readline().strip()
|
||||
nb_div = int(line.split('Test: divisible by ')[1])
|
||||
line = f.readline().strip()
|
||||
v_true = int(line.split('If true: throw to monkey ')[1])
|
||||
line = f.readline().strip()
|
||||
v_false = int(line.split('If false: throw to monkey ')[1])
|
||||
line = f.readline().strip() # empty line
|
||||
|
||||
m_list.append(Monkey(items, operation, operand, nb_div, v_true, v_false))
|
||||
line = f.readline() # monkey
|
||||
|
||||
return m_list
|
||||
|
||||
|
||||
input_file = 'input_example.txt'
|
||||
# input = 'input.txt'
|
||||
|
||||
monkeys = parse_file(input_file)
|
||||
|
||||
|
||||
for n, m in enumerate(monkeys):
|
||||
print(f'monkey {n}')
|
||||
for s in m.sitems:
|
||||
m.items.append(set(prime_factors(s)))
|
||||
m.print()
|
||||
|
||||
# for n, m in enumerate(monkeys):
|
||||
# print(f'monkey {n}')
|
||||
# m.print()
|
||||
nb_round = 20
|
||||
for r in range(0, nb_round):
|
||||
print(f'round {r+1}')
|
||||
for n, m in enumerate(monkeys):
|
||||
# print(f'monkey {n}')
|
||||
m.turn(monkeys)
|
||||
for n, m in enumerate(monkeys):
|
||||
print(f'monkey {n} items: {m.items}')
|
||||
|
||||
# find 2 max
|
||||
active_list = [m.activity for m in monkeys]
|
||||
active_dict = {v: k for k, v in enumerate(active_list)}
|
||||
# print(active_dict)
|
||||
print(sorted(active_dict)[-2:])
|
||||
two_max = sorted(active_dict)[-2:]
|
||||
|
||||
print(two_max[0] * two_max[1])
|
Loading…
Reference in a new issue