-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathday7.py
More file actions
26 lines (20 loc) · 736 Bytes
/
day7.py
File metadata and controls
26 lines (20 loc) · 736 Bytes
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
from collections import defaultdict
from itertools import accumulate
lines = open("../inputs/day7.txt").read().strip().split("\n")
dirSizes = defaultdict(int)
currPath = []
for line in lines:
match line.split():
case "$", "ls":
continue
case "dir", _:
continue
case "$", "cd", "..":
currPath.pop()
case "$", "cd", directory:
currPath.append(directory)
case size, _:
for path in accumulate(currPath, func=lambda a, b: a + "/" + b):
dirSizes[path] += int(size)
print(sum(size for size in dirSizes.values() if size <= 100_000))
print(min(size for size in dirSizes.values() if size >= dirSizes["/"] - 40_000_000))