mirror of
https://github.com/bertptrs/adventofcode.git
synced 2025-12-26 13:20:32 +01:00
Implement day 1
This commit is contained in:
@@ -1,13 +1,28 @@
|
||||
from collections import defaultdict
|
||||
from io import StringIO
|
||||
from typing import Any
|
||||
|
||||
from . import SeparateRunner
|
||||
import numpy
|
||||
|
||||
from . import CombinedRunner
|
||||
|
||||
|
||||
class DayRunner(SeparateRunner):
|
||||
class DayRunner(CombinedRunner):
|
||||
@classmethod
|
||||
def part1(cls, _data: str) -> Any:
|
||||
return "Hello"
|
||||
def run_both(cls, data: str) -> tuple[Any, Any]:
|
||||
data = StringIO(data)
|
||||
nums = numpy.loadtxt(data, dtype=numpy.int32)
|
||||
|
||||
@classmethod
|
||||
def part2(cls, _data: str) -> Any:
|
||||
return "world!"
|
||||
left = nums[..., 0]
|
||||
right = nums[..., 1]
|
||||
|
||||
left.sort()
|
||||
right.sort()
|
||||
|
||||
diff = numpy.abs(left - right).sum()
|
||||
|
||||
counts = defaultdict(int)
|
||||
for val in right:
|
||||
counts[val] += 1
|
||||
|
||||
return diff, sum(counts[v] * v for v in left)
|
||||
|
||||
Reference in New Issue
Block a user