51 lines
1.6 KiB
Python
51 lines
1.6 KiB
Python
|
|
from collections import defaultdict
|
||
|
|
from itertools import permutations, pairwise
|
||
|
|
from solutions import BaseSolution
|
||
|
|
|
||
|
|
|
||
|
|
class Solution(BaseSolution):
|
||
|
|
input_file = "13.txt"
|
||
|
|
|
||
|
|
def __str__(self):
|
||
|
|
return "Day 13: Knights of the Dinner Table"
|
||
|
|
|
||
|
|
def parse_input(self, data):
|
||
|
|
lines = defaultdict(int)
|
||
|
|
|
||
|
|
def parseline(line):
|
||
|
|
a, _w, gain_or_lose, value, _h, _u, _b, _s, _n, _t, b = line.split()
|
||
|
|
units = -int(value) if gain_or_lose == "lose" else int(value)
|
||
|
|
return (f"{a}-{b[:-1]}", units)
|
||
|
|
|
||
|
|
for k, v in [parseline(line) for line in data.strip().splitlines()]:
|
||
|
|
lines[k] = v
|
||
|
|
|
||
|
|
return lines
|
||
|
|
|
||
|
|
def _solve(self, people, puzzle_input):
|
||
|
|
def happiness(seats):
|
||
|
|
neighbours = list(pairwise(seats))
|
||
|
|
neighbours.append((seats[0], seats[-1]))
|
||
|
|
return sum(
|
||
|
|
[
|
||
|
|
sum(puzzle_input["-".join([a, b])] for a, b in neighbours),
|
||
|
|
sum(puzzle_input["-".join([b, a])] for a, b in neighbours[::-1]),
|
||
|
|
]
|
||
|
|
)
|
||
|
|
|
||
|
|
return max(happiness(seats) for seats in permutations(people, len(people)))
|
||
|
|
|
||
|
|
def solve(self, puzzle_input):
|
||
|
|
people = set([ab.split("-")[0] for ab, _v in puzzle_input.items()])
|
||
|
|
return self._solve(people, puzzle_input)
|
||
|
|
|
||
|
|
def solve_again(self, puzzle_input):
|
||
|
|
people = set([ab.split("-")[0] for ab, _v in puzzle_input.items()])
|
||
|
|
people.add("-")
|
||
|
|
return self._solve(people, puzzle_input)
|
||
|
|
|
||
|
|
|
||
|
|
if __name__ == "__main__":
|
||
|
|
solution = Solution()
|
||
|
|
solution.show_results()
|