mirror of
https://github.com/thib8956/advent-of-code.git
synced 2025-08-23 16:01:59 +00:00
some more days
This commit is contained in:
19
2015/day1/day1.py
Normal file
19
2015/day1/day1.py
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
def main(inp):
|
||||||
|
floor = 0
|
||||||
|
basement = -1
|
||||||
|
for i, c in enumerate(inp):
|
||||||
|
if c == "(": floor += 1
|
||||||
|
elif c == ")": floor -= 1
|
||||||
|
if basement == -1 and floor == -1:
|
||||||
|
basement = i + 1
|
||||||
|
print("Part 1: ", floor)
|
||||||
|
print("Part 2: ", basement)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import sys
|
||||||
|
infile = sys.argv[1] if len(sys.argv) > 1 else "example.txt"
|
||||||
|
with open(infile) as inp:
|
||||||
|
main(inp.read().rstrip())
|
||||||
|
|
88
2018/day7/day7.py
Normal file
88
2018/day7/day7.py
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
import re
|
||||||
|
from bisect import insort
|
||||||
|
from collections import defaultdict
|
||||||
|
|
||||||
|
|
||||||
|
def topological_sort(graph, reverse_deps):
|
||||||
|
# find starting nodes: with no incoming edges (aka indegree 0)
|
||||||
|
queue = sorted([task for task in graph.keys() if reverse_deps[task] == set()])
|
||||||
|
order = []
|
||||||
|
seen = set()
|
||||||
|
while queue != []:
|
||||||
|
current = queue.pop(0)
|
||||||
|
if current not in seen:
|
||||||
|
seen.add(current)
|
||||||
|
order.append(current)
|
||||||
|
# add dependencies if all prerequisites are already visited,
|
||||||
|
# insert them in alphabetical order
|
||||||
|
for d in graph[current]:
|
||||||
|
if all(x in order for x in reverse_deps[d]):
|
||||||
|
insort(queue, d)
|
||||||
|
return order
|
||||||
|
|
||||||
|
|
||||||
|
def main(inp):
|
||||||
|
dependencies = defaultdict(set)
|
||||||
|
reverse_deps = defaultdict(set)
|
||||||
|
for l in inp:
|
||||||
|
first, second = re.findall(r"[sS]tep (\w)", l)
|
||||||
|
dependencies[first].add(second)
|
||||||
|
reverse_deps[second].add(first)
|
||||||
|
|
||||||
|
order = topological_sort(dependencies, reverse_deps)
|
||||||
|
print("Part 1: ", "".join(order))
|
||||||
|
|
||||||
|
|
||||||
|
done = []
|
||||||
|
doing = dict()
|
||||||
|
|
||||||
|
workers = 5
|
||||||
|
step = 0
|
||||||
|
number_of_tasks = len(order)
|
||||||
|
while len(done) != number_of_tasks:
|
||||||
|
assert len(doing) <= workers
|
||||||
|
for i in range(workers):
|
||||||
|
# check if the worker has a pending task
|
||||||
|
if i in doing:
|
||||||
|
task = doing[i]
|
||||||
|
if is_task_done(task, step):
|
||||||
|
#print(f"{step}: worker #{i}, task {task} done")
|
||||||
|
del doing[i]
|
||||||
|
done.append(task[0])
|
||||||
|
else:
|
||||||
|
continue
|
||||||
|
next_task = get_task(dependencies, reverse_deps, done, doing)
|
||||||
|
if next_task is not None:
|
||||||
|
#print(f"{step}: worker #{i}, starting task {next_task}")
|
||||||
|
doing[i] = (next_task, step)
|
||||||
|
#print(f"{step}: {doing} {done}")
|
||||||
|
if len(done) == number_of_tasks:
|
||||||
|
break
|
||||||
|
step += 1
|
||||||
|
print(f"{step}\t{'\t'.join(x[0] for x in doing.values())}")
|
||||||
|
print(step)
|
||||||
|
|
||||||
|
def get_task(graph, reverse_deps, done, doing):
|
||||||
|
queue = sorted([task for task in graph.keys() if all(x in done for x in reverse_deps[task])])
|
||||||
|
doingg = [x[0] for x in doing.values()]
|
||||||
|
for t in queue:
|
||||||
|
if t not in done and t not in doingg:
|
||||||
|
return t
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
def is_task_done(task, step):
|
||||||
|
letter, start_t = task
|
||||||
|
duration = ord(letter) - ord("A") + 61
|
||||||
|
if step - start_t >= duration:
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import sys
|
||||||
|
infile = sys.argv[1] if len(sys.argv) > 1 else "example.txt"
|
||||||
|
with open(infile) as inp:
|
||||||
|
main([l.rstrip() for l in inp.readlines()])
|
||||||
|
|
40
2022/day2/day2.py
Normal file
40
2022/day2/day2.py
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
def main(content):
|
||||||
|
table = str.maketrans("XYZ", "ABC")
|
||||||
|
score = 0
|
||||||
|
for c in content:
|
||||||
|
c = c.translate(table)
|
||||||
|
w = ord(c[-1]) - ord("A") + 1
|
||||||
|
match c:
|
||||||
|
case "A A" | "B B" | "C C": score += 3 + w
|
||||||
|
case "A B" | "B C" | "C A": score += 6 + w
|
||||||
|
case "A C" | "B A" | "C B": score += w
|
||||||
|
case _: assert False, c
|
||||||
|
print("Part 1: ", score)
|
||||||
|
|
||||||
|
# x = lose, y = draw, z = win
|
||||||
|
score = 0
|
||||||
|
for c in content:
|
||||||
|
outcome = c[-1]
|
||||||
|
if outcome == "Y":
|
||||||
|
w = ord(c[0]) - ord("A") + 1
|
||||||
|
score += 3 + w
|
||||||
|
elif outcome == "Z":
|
||||||
|
index = ord(c[0]) - ord("A")
|
||||||
|
play = "ABC"[(index + 1) % 3]
|
||||||
|
w = ord(play) - ord("A") + 1
|
||||||
|
score += 6 + w
|
||||||
|
elif outcome == "X":
|
||||||
|
index = ord(c[0]) - ord("A")
|
||||||
|
w = ord("ABC"[index - 1]) - ord("A") + 1
|
||||||
|
score += w
|
||||||
|
else:
|
||||||
|
assert False, outcome
|
||||||
|
print(score)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
import fileinput
|
||||||
|
#main(['A Y', 'B X', 'C Z'])
|
||||||
|
main(list(l.rstrip() for l in fileinput.input()))
|
||||||
|
|
36
2022/day3/day3.py
Normal file
36
2022/day3/day3.py
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
from itertools import zip_longest
|
||||||
|
from functools import reduce
|
||||||
|
from operator import and_
|
||||||
|
|
||||||
|
|
||||||
|
def grouper(n, iterable):
|
||||||
|
"grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx"
|
||||||
|
args = [iter(iterable)] * n
|
||||||
|
return zip_longest(*args)
|
||||||
|
|
||||||
|
|
||||||
|
def split(x):
|
||||||
|
return set(x[:len(x)//2]), set(x[len(x)//2:])
|
||||||
|
|
||||||
|
|
||||||
|
def get_priority(x):
|
||||||
|
x = x.pop()
|
||||||
|
prio = ord(x)
|
||||||
|
if "a" <= x <= "z":
|
||||||
|
prio -= ord("a") - 1
|
||||||
|
else:
|
||||||
|
prio -= ord("A") - 27
|
||||||
|
return prio
|
||||||
|
|
||||||
|
|
||||||
|
def main(content):
|
||||||
|
total = sum(get_priority(reduce(and_, split(l))) for l in content)
|
||||||
|
print("Part 1: ", total)
|
||||||
|
total = sum(get_priority(reduce(and_, map(set, x))) for x in grouper(3, content))
|
||||||
|
print("Part 2: ", total)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
import fileinput
|
||||||
|
main(list(l.rstrip() for l in fileinput.input()))
|
||||||
|
|
45
2022/day4/day4.py
Normal file
45
2022/day4/day4.py
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
|
||||||
|
def contains(first, second):
|
||||||
|
"True if first ⊂ second or second ⊂ first"
|
||||||
|
start_a, end_a = first
|
||||||
|
start_b, end_b = second
|
||||||
|
if start_b >= start_a and end_b <= end_a:
|
||||||
|
return True
|
||||||
|
start_a, end_a = second
|
||||||
|
start_b, end_b = first
|
||||||
|
if start_b >= start_a and end_b <= end_a:
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
def overlaps(first, second):
|
||||||
|
start_a, end_a = first
|
||||||
|
start_b, end_b = second
|
||||||
|
if start_a <= start_b <= end_a:
|
||||||
|
return True
|
||||||
|
if start_b <= start_a <= end_b:
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
def main(content):
|
||||||
|
total = 0
|
||||||
|
for l in content:
|
||||||
|
first, second = [tuple(map(int, x.split("-"))) for x in l.split(",")]
|
||||||
|
if contains(first, second):
|
||||||
|
total += 1
|
||||||
|
print("Part 1: ", total)
|
||||||
|
|
||||||
|
total = 0
|
||||||
|
for l in content:
|
||||||
|
first, second = [tuple(map(int, x.split("-"))) for x in l.split(",")]
|
||||||
|
if overlaps(first, second):
|
||||||
|
total += 1
|
||||||
|
print("Part 2: ", total)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
import fileinput
|
||||||
|
main([l.rstrip() for l in fileinput.input()])
|
||||||
|
|
Reference in New Issue
Block a user