-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpart_one.py
41 lines (29 loc) · 974 Bytes
/
part_one.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
import json
from typing import Any, override
from infrastructure.solutions.base import Solution
class Year2015Day12Part1Solution(Solution):
@classmethod
@override
def parse_input(cls, text_input: str) -> dict[str, str]:
return {'items': json.loads(text_input)}
@classmethod
@override
def solve(cls, items: list[Any]) -> int:
"""
Time: O(n*m)
Space: O(m)
Where n - total number of objects,
m - maximum size of object
"""
return cls.sum_numbers(items)
@classmethod
def sum_numbers(cls, item: Any) -> int:
if isinstance(item, dict):
return sum(cls.sum_numbers(value) for value in item.values())
if isinstance(item, list):
return sum(cls.sum_numbers(value) for value in item)
if isinstance(item, int):
return item
return 0
if __name__ == '__main__':
print(Year2015Day12Part1Solution.main())