advent-of-code/2018/day-09/01.py

48 lines
1.1 KiB
Python

num_players = 419
num_marbles = 71052
class Node:
def __init__(self, val):
self.val = val
self.prev = None
self.next = None
def insert(self, val):
new = Node(val)
new.prev = self
new.next = self.next
if self.next is not None:
self.next.prev = new
self.next = new
return new
def remove(self):
if self.prev is not None:
self.prev.next = self.next
if self.next is not None:
self.next.prev = self.prev
self.next = None
self.prev = None
cur_node = Node(0)
cur_node.next = cur_node
cur_node.prev = cur_node
score = {x: 0 for x in range(1, num_players + 1)}
cur_marble = 1
while cur_marble <= num_marbles:
cur_player = (cur_marble - 1) % num_players + 1
if cur_marble % 23 == 0:
tmp = cur_node.prev.prev.prev.prev.prev.prev.prev
cur_node = tmp.next
tmp.remove()
score[cur_player] += cur_marble + tmp.val
else:
cur_node = cur_node.next.insert(cur_marble)
cur_marble += 1
print(max(score.values()))