did day6 p1 and started p2
This commit is contained in:
parent
2a7a59b949
commit
311ab759a7
130
2024/day6/input.text
Normal file
130
2024/day6/input.text
Normal file
@ -0,0 +1,130 @@
|
||||
.........................................#.....#..##.....................#...........................#.....................#....#.
|
||||
..................#................................#..#.................................#................#........................
|
||||
.....##.........#..#........#......#............#.....#..................#............................#...#...#..#...#............
|
||||
#..#...#....#...#.................................#.........................................#...............................#.....
|
||||
.................##...................................................#.........................#....................#............
|
||||
.............#.............#...................#...................#..................................#....#..#........#....#.....
|
||||
..#.........................................................................................##....#.................#.............
|
||||
...........#.........#.....#..#.................#...........##..........#....#....................................#........#.#....
|
||||
#...#.........................................#..........................................................#........................
|
||||
.............................................#................................#...............................##..........#.......
|
||||
......#....#..............#..........................................#....#........................#...................##....#....
|
||||
........#.#..............................#..#.............#.......#............................................................#..
|
||||
....#...............#...#..#......#...........................#........................#...........#...#...................#......
|
||||
..........................#...........##....#.......................................#..........................#.#................
|
||||
....................#.........................................................#........#..........................................
|
||||
..............#.............#.##.............#.........#..........#.......................................#...#.........#..#......
|
||||
...............................................................#..........#........#.........#.............#.............#........
|
||||
............#.................#...................#....#......................................................................#...
|
||||
.......#....##....#......##.........#...........................................#....................................#.........#..
|
||||
......#...#......................#............................##....##....................#.......................................
|
||||
...................................##....................#.............................#........................#.................
|
||||
..........................#.#.........................#..........................................................#................
|
||||
.............#...#..........................................................#..#.#.#.....#....#.....#...................#........#
|
||||
....#......#.............#...#......#.........#............##..................#.......................#..........................
|
||||
.......................#.....#...................................#..........................#.....................................
|
||||
#.....##....................................#.....#.....................................................#....#....................
|
||||
............#...#...................................................................#.........#......................#............
|
||||
................#....................................#.....#.........#.........#..............#...................................
|
||||
..........................................................................................#.....#.#...#.........#.......#.........
|
||||
#.............#..............................................#...#.#..#.....................#...#............#.#...#..............
|
||||
..........................................#..................................................................#...#................
|
||||
.........#.............................................#................................#.................#.....#................#
|
||||
........................................................................................#.......#.....#..........#..........#.....
|
||||
...........................#.......#......#..........#............#...............#........#...#......#...........................
|
||||
...##...................#.................................#..................................##...................................
|
||||
........................................................#.#.#.....#............................##................#................
|
||||
......................................#....................#..................#...#.............................#...........#.....
|
||||
.............................#...#.................#.............................#..............#.................................
|
||||
#.....................................................................................................................#..#.....#..
|
||||
...........................#..............................................#................................#....................#.
|
||||
......#..................##................#....................#.............................................................#..#
|
||||
.................#....................................................................................#...........................
|
||||
....#.#..................................#..#........................##...#.............................#..............#..........
|
||||
...............................................................................................................#...#.....#........
|
||||
..#...................#.......................#........................................................................#..........
|
||||
..#............#......................................###.........#..............................#..........#.................#...
|
||||
.................................#..........................................................................#............#........
|
||||
......................#...#...............#..............................#.......#........................#...........#........#..
|
||||
..#..................#............................................................................#......#........................
|
||||
..........................................................................#....#........#...................#.............#.......
|
||||
..............#.........#.#............................................................................................#..........
|
||||
........................#...#............................................#..............................#.........................
|
||||
.........................................#...................................................#........................#...........
|
||||
...#.................................................#..........#.............................#.....#.#.........#.................
|
||||
............................#...........#...............................................................#........................#
|
||||
..........................#..#..................#....................................#..................#.......................#.
|
||||
......#...................#..............................#........#.##..........................................................#.
|
||||
...........................#.....#.............................................................................#..................
|
||||
..............#........................................................#.#.......#...#................#....#......................
|
||||
...#...#..........................................................................................................................
|
||||
..........##.....................#.#.............#...............................#.........................................#......
|
||||
.#.#...................#.................................#.................................................#....#.................
|
||||
........................#..............................................................................................#.......#..
|
||||
...#....................................................................................................#.....##.....#............
|
||||
.............#........................#.....................................................#.............#....................#.#
|
||||
#........................................................................................#.....#..................................
|
||||
........#..............#...............................#.......#...................................#..........#...................
|
||||
.....................#.........................#.......#.......#.....#...........................................................#
|
||||
...............#.....................................................................#..........#.................................
|
||||
.................................#....#..........#..............................#...........#............................#........
|
||||
..............#......#.........#...#.............#.......................#....#...................................................
|
||||
...........................................................^.......................................................#..............
|
||||
..........#...............................#.........................#.....................................................#.....#.
|
||||
.##.....................#....................#.....#.......................................................#..##...#..........#...
|
||||
.......................#...........#..#.#.....................................................#....................#..............
|
||||
..................................................................#......#.............#..................................#.......
|
||||
.#............................................#........................#...................................#.........#............
|
||||
..................................................................................#.##.........................#..................
|
||||
................#........#...........................................#...................................#........................
|
||||
...............#........#....#...................#................................#........#.....#..........#.................#...
|
||||
.....#.............................#..........................................................................................#...
|
||||
............#..............#.....#........................................#............#............##..........#.................
|
||||
........................................................................................#..........................#........##....
|
||||
..#............................#...#.................................#....#..............#........................................
|
||||
...#.....................#...........................................................................#.....................#......
|
||||
....#.........................#.............#..................................#.........#..............#.........................
|
||||
.....................#...................................................................................#..#......#..............
|
||||
.....#.................................#...............................#.....#..........#.........................................
|
||||
............#........#..........#....................#....................#..#.#.....................................#............
|
||||
........................................#......#......................#......................................#..#.......#.........
|
||||
...#...........#...............#.................#.............................................#..........#...#...................
|
||||
.......#....##..............................#......#.......................#..................#..........#.................#...#..
|
||||
.................................##...........................................................#....#..........#.#........#........
|
||||
..................................#....##..#..#.......#............................#............#.#........................#......
|
||||
..........................................#.....................................#.............##...#............#.................
|
||||
....#....................#................................#....#..#.....................#................#...#..#..#..............
|
||||
.............#...#..............................................................................#.................................
|
||||
..........#..........................#.......................................#....................#..#.......#.........#.....#....
|
||||
......................#............#...............#.....#.................#...............................#...#....#.........##..
|
||||
..........................................................................##.............................#...#..............#.....
|
||||
#.#...#..................................................#..................................#..#...#..............................
|
||||
...........................................#....#..............#.........................#........................................
|
||||
...........#....................#.....................##........................#.....#...................................#....#..
|
||||
..........#..........#.................................................#...............................................#..........
|
||||
.....................................................................................#......#.....................#.#.............
|
||||
........#.#..........................#...............................................................................#............
|
||||
..............#..#.............#...........#......................#....#..#......#...................#............................
|
||||
........#.......#.................#........#..........#.....................#.........................................#...........
|
||||
..........................................................#...................................#.....#.........#......#...#........
|
||||
..........#.....#.....................#............#............#.#......................#....#.##.............#...........#......
|
||||
...#.#..#.......#......#........#...........................#....................#.....#.........#...........#.................#..
|
||||
........#.......................................#............#.............#..................#......#......#...............#.#...
|
||||
....................#.....#........#.........................#.................................................#................#.
|
||||
.......#..#...........................................#......#..................#..#......................#..#....................
|
||||
#.#........#....#...#.............................................#............................#.....................#............
|
||||
#...................#...........#...................#..#................................................................#.#.......
|
||||
............#...#.#...........#..#.....................................................................#........................#.
|
||||
...#..............................................#..............#......#...#..............................................#......
|
||||
................#...#..#..................................................................................................##...#..
|
||||
.............................#...#..#........#.........#...#...................#............................................#.....
|
||||
............#......................#.......................................................#.#....................................
|
||||
...#......................#......#.#...........................................#.....#....#......................#...#............
|
||||
.....#..#..........#.............................#..........................................#............#..................#.....
|
||||
.................#...#.......................#..................................................#....................#............
|
||||
............#..................................................#.....#..............#.......#.............................#.#....#
|
||||
........#.............#..#.......................................................................................#.........#......
|
||||
......#...................#..........................................................#................#................#.........#
|
||||
..................#...........................#.....#....#.......................................#..#......................#......
|
||||
....................#....................................#....................#........#............#........#....#...............
|
||||
.........#..............#....#.............................#..#..........#........#.....................#.#.........#.............
|
||||
96
2024/day6/main.py
Normal file
96
2024/day6/main.py
Normal file
@ -0,0 +1,96 @@
|
||||
with open('input.text', 'r') as file:
|
||||
data: list[str] = file.readlines()
|
||||
|
||||
y_bound = len(data)
|
||||
x_bound = len(data[0])
|
||||
|
||||
class Vector:
|
||||
x: int
|
||||
y: int
|
||||
|
||||
def __init__(self, x: int, y: int):
|
||||
self.x = x
|
||||
self.y = y
|
||||
|
||||
def __add__(self, other):
|
||||
return Vector(self.x + other.x, self.y + other.y)
|
||||
|
||||
def __str__(self):
|
||||
return f'{self.x}, {self.y}'
|
||||
|
||||
def __eq__(self, value):
|
||||
return self.x == value.x and self.y == value.y
|
||||
|
||||
class Guard:
|
||||
pos: Vector
|
||||
dir: Vector
|
||||
|
||||
def __init__(self, p: Vector, d: Vector):
|
||||
self.pos = p
|
||||
self.dir = d
|
||||
|
||||
def move(self, ob) -> bool:
|
||||
new_pos = self.pos + self.dir
|
||||
|
||||
# Check if need to turn
|
||||
if new_pos in ob:
|
||||
self.turn()
|
||||
return self.move(ob)
|
||||
|
||||
# Check if move out of bounds
|
||||
if new_pos.y < 0 or new_pos.y >= y_bound or new_pos.x < 0 or new_pos.x >= x_bound:
|
||||
return False
|
||||
|
||||
self.pos = new_pos
|
||||
return True
|
||||
|
||||
|
||||
def turn(self):
|
||||
temp_x = self.dir.x
|
||||
self.dir.x = -self.dir.y
|
||||
self.dir.y = temp_x
|
||||
|
||||
# Parse Data
|
||||
obstacles = []
|
||||
guard = None
|
||||
|
||||
for y, line in enumerate(data):
|
||||
for x, char in enumerate(line):
|
||||
match char:
|
||||
case '#':
|
||||
obstacles.append(Vector(x, y))
|
||||
case '^':
|
||||
guard = Guard(Vector(x, y), Vector(0, -1))
|
||||
|
||||
starting_pos = guard.pos
|
||||
|
||||
# Part 1
|
||||
been = [starting_pos]
|
||||
|
||||
while guard.move(obstacles):
|
||||
if guard.pos not in been:
|
||||
been.append(guard.pos)
|
||||
|
||||
print(f'Part 1: {len(been)}')
|
||||
|
||||
# Part 2
|
||||
total = 0
|
||||
|
||||
been.remove(starting_pos)
|
||||
for place in been:
|
||||
temp_obstacles = obstacles.copy()
|
||||
temp_obstacles.append(place)
|
||||
|
||||
guard.pos = starting_pos
|
||||
guard.dir = Vector(0, -1)
|
||||
|
||||
steps = 0
|
||||
while guard.move(temp_obstacles):
|
||||
steps += 1
|
||||
|
||||
# Yup, this is what I count as in a loop...
|
||||
if steps >= 10 ** 5:
|
||||
total += 1
|
||||
break
|
||||
|
||||
print(f'Part 2: {total}')
|
||||
10
2024/day6/test.text
Normal file
10
2024/day6/test.text
Normal file
@ -0,0 +1,10 @@
|
||||
....#.....
|
||||
.........#
|
||||
..........
|
||||
..#.......
|
||||
.......#..
|
||||
..........
|
||||
.#..^.....
|
||||
........#.
|
||||
#.........
|
||||
......#...
|
||||
Loading…
x
Reference in New Issue
Block a user