These are already done in Elixir, so this is just done for the flex. Also, coming from Day 16-18 from 2023 calendar, it is safe to say 2015 puzzles are easier and more manageable.
31 lines
854 B
Python
31 lines
854 B
Python
class BaseSolution:
|
|
input_file = None
|
|
trim_input = True
|
|
|
|
def read_input(self, filename):
|
|
filepath = "./inputs/{}".format(filename)
|
|
with open(filepath, "r") as f:
|
|
data = f.read()
|
|
if self.trim_input:
|
|
return data.strip()
|
|
return data
|
|
|
|
def show_results(self):
|
|
data = self.read_input(self.input_file)
|
|
puzzle_input = self.parse_input(data)
|
|
print(
|
|
"\n--- {} ---\n 1. {}\n 2. {}".format(
|
|
str(self),
|
|
self.solve(puzzle_input),
|
|
self.solve_again(puzzle_input),
|
|
)
|
|
)
|
|
|
|
def solve(self, puzzle_input):
|
|
raise NotImplementedError
|
|
|
|
def solve_again(self, puzzle_input):
|
|
raise NotImplementedError
|
|
|
|
def parse_input(self, data):
|
|
raise NotImplementedError
|