Solve 2021:3 "Binary Diagnostic"
Yes, I do "".join(). Python is not always beautiful. I began reusing part 1 for part 2, until I realised you cannot reuse the Counter.most_common, and you need the actual values to be able to se equal occourences. I probably lost 5-15 minutes just to dribble with 3 levels of nested objects. In GMT+1 before coffee, that cost me. Part 2 was way uglier before some well motivated refactoring. Since all tests and expected output were in place, refactoring was easy.
This commit is contained in:
parent
d63c7463cc
commit
99f5385f25
2 changed files with 84 additions and 0 deletions
43
2021-python/solutions/day_03.py
Normal file
43
2021-python/solutions/day_03.py
Normal file
|
|
@ -0,0 +1,43 @@
|
||||||
|
from collections import Counter
|
||||||
|
from solutions import BaseSolution
|
||||||
|
|
||||||
|
|
||||||
|
class Solution(BaseSolution):
|
||||||
|
input_file = "03.txt"
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return "Day 3: Binary Diagnostic"
|
||||||
|
|
||||||
|
def parse_input(self, data):
|
||||||
|
return data.split()
|
||||||
|
|
||||||
|
def solve(self, puzzle_input):
|
||||||
|
e, g = self._eg(puzzle_input)
|
||||||
|
return int("".join(g), 2) * int("".join(e), 2)
|
||||||
|
|
||||||
|
def solve_again(self, puzzle_input):
|
||||||
|
og = self._ogco2(puzzle_input, "1")
|
||||||
|
co2 = self._ogco2(puzzle_input, "0")
|
||||||
|
return int("".join(og), 2) * int("".join(co2), 2)
|
||||||
|
|
||||||
|
def _eg(self, puzzle_input):
|
||||||
|
e = []
|
||||||
|
g = []
|
||||||
|
for r in zip(*puzzle_input):
|
||||||
|
x, y = Counter(r).most_common()
|
||||||
|
e.append(x[0])
|
||||||
|
g.append(y[0])
|
||||||
|
return e, g
|
||||||
|
|
||||||
|
def _ogco2(self, values, default, i=0):
|
||||||
|
eg = [Counter(r).most_common() for r in zip(*values)]
|
||||||
|
k = default if eg[i][0][1] == eg[i][1][1] else eg[i][abs(int(default) - 1)][0]
|
||||||
|
rem = [v for v in values if v[i] == k]
|
||||||
|
if len(rem) == 1:
|
||||||
|
return rem
|
||||||
|
return self._ogco2(rem, default, i + 1)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
solution = Solution()
|
||||||
|
solution.show_results()
|
||||||
41
2021-python/tests/test_day_03.py
Normal file
41
2021-python/tests/test_day_03.py
Normal file
|
|
@ -0,0 +1,41 @@
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
from solutions.day_03 import Solution
|
||||||
|
|
||||||
|
|
||||||
|
class Day03TestCase(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.solution = Solution()
|
||||||
|
self.puzzle_input = self.solution.parse_input(
|
||||||
|
"""
|
||||||
|
00100
|
||||||
|
11110
|
||||||
|
10110
|
||||||
|
10111
|
||||||
|
10101
|
||||||
|
01111
|
||||||
|
00111
|
||||||
|
11100
|
||||||
|
10000
|
||||||
|
11001
|
||||||
|
00010
|
||||||
|
01010
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_parse_puzzle_input(self):
|
||||||
|
data = """
|
||||||
|
00100
|
||||||
|
11110
|
||||||
|
"""
|
||||||
|
assert self.solution.parse_input(data) == ["00100", "11110"]
|
||||||
|
|
||||||
|
def test_solve_first_part(self):
|
||||||
|
assert self.solution.solve(self.puzzle_input) == 198
|
||||||
|
|
||||||
|
def test_solve_second_part(self):
|
||||||
|
assert self.solution.solve_again(self.puzzle_input) == 230
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
unittest.main()
|
||||||
Loading…
Add table
Reference in a new issue