Adding day3-5
This commit is contained in:
parent
a4ac698f7a
commit
87b0f10776
43
2024/day3/main.py
Normal file
43
2024/day3/main.py
Normal file
@ -0,0 +1,43 @@
|
||||
import sys
|
||||
import os
|
||||
import re
|
||||
sys.path.insert(1, os.path.abspath('../../'))
|
||||
from python_tools.aoc_utils import *
|
||||
|
||||
def part_one(input):
|
||||
pt_1=0
|
||||
list_of_mults = re.findall(r"mul\(\d{1,3},\d{1,3}\)", input)
|
||||
for i in list_of_mults:
|
||||
numbers = re.findall(r"\d{1,3}", i)
|
||||
pt_1 += int(numbers[0]) * int(numbers[1])
|
||||
# print(numbers)
|
||||
print("Part One: ", pt_1)
|
||||
|
||||
def part_two(input):
|
||||
off=False
|
||||
pt_2=0
|
||||
re1 = r"mul\(\d{1,3},\d{1,3}\)"
|
||||
re2 = r"do\(\)"
|
||||
re3 = r"don't\(\)"
|
||||
list_of_mults = re.compile("(%s|%s|%s)" % (re1, re2, re3)).findall(input)
|
||||
# list_of_mults = re.findall(r"do\(\)"+r"mul\(\d{1,3},\d{1,3}\)", input)
|
||||
for i in list_of_mults:
|
||||
if "don't()" == i:
|
||||
off = True
|
||||
elif "do()" == i:
|
||||
off = False
|
||||
else:
|
||||
if not off:
|
||||
numbers = re.findall(r"\d{1,3}", i)
|
||||
pt_2 += int(numbers[0]) * int(numbers[1])
|
||||
print("Part One: ", pt_2)
|
||||
|
||||
def main():
|
||||
f = open("input.txt", 'r')
|
||||
input = f.read()
|
||||
part_one(input)
|
||||
part_two(input)
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
74
2024/day4/main.py
Normal file
74
2024/day4/main.py
Normal file
@ -0,0 +1,74 @@
|
||||
import sys
|
||||
import os
|
||||
sys.path.insert(1, os.path.abspath('../../'))
|
||||
from python_tools.aoc_utils import *
|
||||
|
||||
|
||||
row_limit=0
|
||||
col_limit=0
|
||||
|
||||
def check_if_spells_xmas(input, base_row, base_col, dir_row, dir_col):
|
||||
if ((base_row+dir_row*4 > row_limit) or (base_row+dir_row*3 < 0) or
|
||||
(base_col+dir_col*4 > col_limit) or (base_col+dir_col*3 < 0)):
|
||||
return False
|
||||
for count, i in enumerate('XMAS'):
|
||||
if input[base_row + count*dir_row][base_col + count*dir_col] != i:
|
||||
return False
|
||||
|
||||
return True
|
||||
|
||||
def get_string(input, row, col, dir):
|
||||
x = ""
|
||||
for count in [-1,0,1]:
|
||||
x += input[row+(dir*count)][col+count]
|
||||
return x
|
||||
|
||||
def check_if_spells_mas(input, base_row, base_col):
|
||||
if ((base_row+1 >= row_limit) or (base_row-1 < 0) or
|
||||
(base_col+1 >= col_limit) or (base_col-1 < 0)):
|
||||
return False
|
||||
cris = False
|
||||
cross = False
|
||||
test_str = get_string(input, base_row, base_col, 1)
|
||||
cris = (test_str == 'MAS' or test_str == 'SAM')
|
||||
test_str = get_string(input, base_row, base_col, -1)
|
||||
cross = (test_str == 'MAS' or test_str == 'SAM')
|
||||
return (cris and cross)
|
||||
|
||||
|
||||
def part_one(input):
|
||||
pt_1 = 0
|
||||
global row_limit
|
||||
global col_limit
|
||||
row_limit=len(input)
|
||||
col_limit=len(input[0])
|
||||
for row in range(len(input)):
|
||||
for col in range(len(input[row])):
|
||||
if input[row][col] == 'X':
|
||||
for i in [-1,0,1]:
|
||||
for j in [-1,0,1]:
|
||||
if check_if_spells_xmas(input, row, col, i, j):
|
||||
pt_1 += 1
|
||||
print("Part One: ", pt_1)
|
||||
|
||||
def part_two(input):
|
||||
pt_2 = 0
|
||||
global row_limit
|
||||
global col_limit
|
||||
row_limit=len(input)
|
||||
col_limit=len(input[0])
|
||||
for row in range(len(input)):
|
||||
for col in range(len(input[row])):
|
||||
if input[row][col] == 'A':
|
||||
if check_if_spells_mas(input, row, col):
|
||||
pt_2 += 1
|
||||
print("Part One: ", pt_2)
|
||||
|
||||
def main():
|
||||
contents = file2list("input.txt")
|
||||
part_one(contents)
|
||||
part_two(contents)
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
89
2024/day5/main.py
Normal file
89
2024/day5/main.py
Normal file
@ -0,0 +1,89 @@
|
||||
import sys
|
||||
import os
|
||||
sys.path.insert(1, os.path.abspath('../../'))
|
||||
from python_tools.aoc_utils import *
|
||||
import collections as C
|
||||
|
||||
rules = []
|
||||
updates = []
|
||||
|
||||
def get_middle(u):
|
||||
assert(len(u) % 2 == 1)
|
||||
return u[int((len(u)-1)/2)]
|
||||
|
||||
def check_rule_break(r, visited):
|
||||
for i in visited:
|
||||
if i in r:
|
||||
return True
|
||||
return False
|
||||
|
||||
def part_one(rules, updates):
|
||||
pt_1 = 0
|
||||
G = C.defaultdict(list)
|
||||
for r in rules:
|
||||
G[r[0]].append(r[1])
|
||||
|
||||
count = 0
|
||||
for u in updates:
|
||||
update_valid = True
|
||||
visited = []
|
||||
for i in u:
|
||||
if check_rule_break(G[i], visited):
|
||||
update_valid = False
|
||||
break
|
||||
else:
|
||||
visited.append(i)
|
||||
if update_valid:
|
||||
# print(f"{count} valid {get_middle(u)}, {u}")
|
||||
pt_1 += get_middle(u)
|
||||
count += 1
|
||||
|
||||
print("Part One: ", pt_1)
|
||||
|
||||
|
||||
def swap_order(u, G):
|
||||
for count, i in enumerate(u):
|
||||
for c in range(count):
|
||||
if i in G[u[c]]:
|
||||
u.insert(c, u.pop(count))
|
||||
break
|
||||
|
||||
def part_two(input):
|
||||
pt_2 = 0
|
||||
G = C.defaultdict(list)
|
||||
for r in rules:
|
||||
G[r[0]].append(r[1])
|
||||
|
||||
count = 0
|
||||
for u in updates:
|
||||
order_needs_to_be_swapped = False
|
||||
visited = []
|
||||
for i in u:
|
||||
if check_rule_break(G[i], visited):
|
||||
order_needs_to_be_swapped = True
|
||||
break
|
||||
else:
|
||||
visited.append(i)
|
||||
if order_needs_to_be_swapped:
|
||||
swap_order(u, G)
|
||||
pt_2 += get_middle(u)
|
||||
count += 1
|
||||
|
||||
print("Part One: ", pt_2)
|
||||
|
||||
|
||||
def main():
|
||||
f = open("input.txt")
|
||||
contents = f.read().split()
|
||||
for c in contents:
|
||||
if "|" in c:
|
||||
rules.append(list(map(int, (c.split("|")))))
|
||||
elif "," in c:
|
||||
updates.append(list(map(int,c.split(","))))
|
||||
part_one(rules, updates)
|
||||
|
||||
part_two(contents)
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
Loading…
Reference in New Issue
Block a user