advent-of-code/2018/day-11/02.py

35 lines
911 B
Python
Raw Normal View History

2018-12-11 10:47:24 +01:00
serial = 5535
cache = dict()
def get_power_level(x, y):
if (x, y) in cache:
return cache.get((x, y))
rack_id = x + 10
power_level = rack_id * y
power_level += serial
power_level *= rack_id
power_level = (power_level // 100) % 10
power_level -= 5
cache[(x, y)] = power_level
return power_level
m = dict()
for size in range(1, 301):
# for size in range(1, 4):
print('checking size:', size)
for x in range(0, 301 - size):
for y in range(0, 301 - size):
level = m.get((x, y, size - 1)) or 0
j = size - 1
for i in range(0, size - 1):
level += get_power_level(x + i, y + j)
level += get_power_level(x + j, y + i)
level += get_power_level(x + size - 1, y + size - 1)
m[(x, y, size)] = level
pos = max(m, key=m.get)
print(f'{pos[0]},{pos[1]},{pos[2]}')