-
-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
2 changed files
with
156 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
\..|.....................|.-........\.............-................|./....|.....-...-......................... | ||
.......\.........|..............-...||..............-...........--.|...............||..........\............|. | ||
........../.....................\.........\..................\....|.....-.................../..-.\............ | ||
................/..../........../..-....|\.|...-...................\....|/........|........................... | ||
.....|../-\.|....|................................--.-./..........|.........../..-....-................-....|. | ||
.../..........\................-.......\................|/..\.................\.....\...|....../............./ | ||
..-../.../......-.....\........//.............|.........../...|.........../.......-........................... | ||
......\....../......./..|\............/..........................\..............\.....\.........|......-...|.. | ||
.|/.......\.........|...../..//...................................-....-...........././-...............-...... | ||
........-....../......./..\.............|.....................\........../-....../........-................... | ||
......-........./\..................../..\|..-//....|.\--................|.....|.../............-............\ | ||
........................|...-........|..............|..............|................./........................ | ||
...................|................|..../...-...................../...|......\..................|...|\....... | ||
....-......../.\...............\-...\...........................................................|............. | ||
.............../.|.......|.........\.\.........................-|.............\........-.../...-...||......... | ||
....-...-\.-............/...../...../..\........\|....\...............\.............-........................\ | ||
........././.......//......-...|...........-...|..|....-......-.......|............................|../....... | ||
\.................|..../.....-..|......./.....................\....../...|./\.\...............-............./. | ||
.....-\............../...................................../....\.....-|...........-.\...../............\..... | ||
......................./..\..................|...............-.........-..../......../..|..................... | ||
....\...................../...../......|...........................\......||.\...-..............-...........|. | ||
..........................|........../...........|....-.......\........................-|..\............/..|.. | ||
-./...|..............................................|./../.........-|.\.|..........\........../.........\.... | ||
...........|......................-............................|.........................\....-........../.... | ||
........................|/....\......../.|.......\.........../..................\........................-.... | ||
...../.................-............................-.\......|...............\...........\.....-.............- | ||
....|-.............-.../....\...........-...........|\.............-.............../-....../.................. | ||
...............\/.............../.|............................/.|...................-............-........... | ||
.................\.....\........./......../.....\.....|........-..\..........................|................ | ||
...............-..-........-........../...../...\.................\..-.-.....|..........\..............\...... | ||
.............-....../....|.\\............|......|.........-.......|................/.......|./............\... | ||
.................................................\.......\-....\.........|.....-..|.........-................/ | ||
.............../..............\..........................\.................-\............-............-....... | ||
/....|...../.....................................................-....\.....-................../..........-..\ | ||
.....\.....................-...........|...\.....-...../.......-.|.................|.......................... | ||
.............-..........-....-....-.-../....|.......-.\.........................-........../..../.....\....... | ||
..........\\.........................../...-........./........\............|.........../...................... | ||
............-......|..................................................................-......./...-........... | ||
........\............-......|....\............................\.\........|......................../......\...- | ||
......../...|........|..-.-.../..../..........|........|....../....../../...........\.............\....../.... | ||
......|.........-........//........-../....\........./..........|.-......-...-......-.............\..|........ | ||
./......................../................-..........................................-.....--....|........... | ||
....../............\\..../\............|..-.|.|.-.............-........|................................./.../ | ||
..-......../.......|.......|........................-....-..............................-..................... | ||
.........||............|.\................|......................./.\...............-..........|..../..-..\... | ||
\|.......|..\..........-.................../|.....-.............\............./....................../........ | ||
.....................|....-.../...............\.\............................................................. | ||
............|.......................\...........-......|...././.-...../................|........-..........\.\ | ||
..........|../\.|.......|\..-............\.-..............-....../...\......||..\........-.\..../...\......./| | ||
..|.....................................-\............//.......|..\..............\.........|....|............. | ||
.....\...............................-........./..........\.........-....|..........-./../...\................ | ||
.....\./....-...\....................\|.........\.............-...\..........-...............|............./.. | ||
/./\......\.........\........-../......../.....|/..................../.././..-......................|\........ | ||
.|\...-.\\.......................|........-\.....|......|......./|..........-..../...................|.|...... | ||
...........\.............\./....|./.............................|............................................. | ||
.../...../.|.................\...../.....-..............|.\.\../.................../.............\............ | ||
..............\............-........-........\....../............|....|...\....\...|.....-..../............... | ||
/.\.\........-....\.|....-....\..../...-./...............-.......\../........./..../........./.......\........ | ||
|..............................-..\............................\......//........\../...-../..\......../....... | ||
.............\.../.\............\--............|................-|............|......../...................... | ||
...../....|................................-.....................................|./..........|.........\.\\.. | ||
........./......-.....|............/.-.......\..-.......................................|..................\.. | ||
.......\.\.....................-|...../.....|........|............-..............-....../\..\....../.......... | ||
|..\.|........../|..\..|\..-...................\.................../.....-/...............|................../ | ||
...........|..-..............|........................-..............-...............-.............\.........\ | ||
...\./.....-...|.-.......-................/.\.....-..-...|......-.......................................--...| | ||
...............-.........|............-............|./.......\...../.....\............-.\..................... | ||
..................|......|..........-..............................-....|............|.\........./..-......... | ||
|......................../.....-../|.....\./..\....|......................./........................./...\.... | ||
....|............-........\..-...............-................/\..........................|........|.......\-. | ||
|......./.....\.......\..................-.\..../....|............|.../..................../|.../........../.. | ||
...-|..................||......--......\......|.............|\........./.................\......\........\.... | ||
./........./........-...................................\......-......................................-.....-. | ||
.....\..-\-....\........................|........../.......|.........-.............................///........ | ||
./.............\........./.................|.....................|..\.........../...|...|..\.|............-... | ||
.................................\.................................\...........................-.........-.... | ||
...................\....|...............|...............\..../.....-.....................................\.... | ||
.../.......-.......|...........|.....\..................../......................|../.............\........... | ||
......-....................../..../.....-..............\............./...........-.....\....|...............|. | ||
......-.......-.......|..................\................-...|./.......--............../.......|.-.|......... | ||
-..................\........../..........................-...-.............../..............................|. | ||
............/.........-..../\..-.....\....\........./.........\.........../.........|/.../.................... | ||
...................................../.....|..\.............\..........-.......\............../.............|. | ||
..../........./.........................-.......\..|..|.....--|...../.............../..-/./.......|..../|..... | ||
.........\.|...|..|-...................................\../..-.....|....\....................-................ | ||
..../..-......|..............\../............./..........-.|......../..........|.\........|..................- | ||
......|.................\..........\|...................-.../.\.........../.|............../................./ | ||
.........................\.................................../-./............................-..-.........|... | ||
\...........-................/....-.-....................................../...../..............\.......-\.../ | ||
-....................................\.........................../.............................|.............. | ||
......................\............\.......\..\.............\.................-....\....-.|................... | ||
.|-.-...../......./............./........|.................../.........-..\........./.\|...........-.......... | ||
.......\..............\.....-..........\.|.\...|.........\/..........\......|.\...................-........... | ||
../.-..................../..................|.....-...-....-............................-.-..-../..\.......... | ||
.................................-.......|...../.\.................\..../................................-.... | ||
.-..|.....|.........-........|....-.........../...........\......-..........................\................. | ||
..-.................../...|..-..|...................../...-...|........................................./|.... | ||
.........................-\............................./....................../.......-................|..... | ||
........../.......\.........|...-/........./............./......................../...........-../..\.-\...-.. | ||
..........|....\-........\...................-.|....-.........\................../.......\.................... | ||
/...-..........\......\.........|.............|...........-....../.|..|..-............................|....... | ||
.........\.|........\......\....|.........................................../........-........................ | ||
....\.....|.......\....................................-............|.....-........./..\...\.....-..-......... | ||
.|../...../.......|\......\............../....\..|..-...-..............|-.................................-... | ||
.|.\......./........../........|..\.../|......\....|.........-.|.................-.........|............./..-. | ||
...............-.................|...-../\..../.......-.....|..\./............................................ | ||
....-.|.........-........................../...................|...............\........................../... | ||
..|/...-..../../...-........-...-.....................................\....................................... | ||
............../....|.....-\.....-................................../\.....................\....-........-..... | ||
......../.|.................|......|.|.-....|...................../....................................\...... |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
from math import inf | ||
|
||
|
||
with open("input") as f: | ||
ls = f.read().strip().split("\n") | ||
|
||
board = {i + 1j * j: x for i, l in enumerate(ls) for j, x in enumerate(l)} | ||
|
||
|
||
def energized(entry, d): | ||
q = [(entry - d, d)] | ||
seen = set() | ||
while q: | ||
z, d = q.pop() | ||
if (z, d) in seen: | ||
continue | ||
seen.add((z, d)) | ||
newz = z + d | ||
if newz not in board: | ||
continue | ||
match board[newz]: | ||
case "|" if d.imag: | ||
new_dir = [1, -1] | ||
case "-" if d.real: | ||
new_dir = [1j, -1j] | ||
case "/": | ||
new_dir = [(d * 1j).conjugate()] | ||
case "\\": | ||
new_dir = [(d * -1j).conjugate()] | ||
case _: | ||
new_dir = [d] | ||
q += [(newz, newd) for newd in new_dir] | ||
return len({x[0] for x in seen}) - 1 | ||
|
||
|
||
# Part 1 | ||
print(energized(0, 1j)) | ||
|
||
# Part 2 | ||
m = -inf | ||
N, M = len(ls), len(ls[0]) | ||
entries = [(i, 1j) for i in range(N)] | ||
entries += [(i + (M - 1) * 1j, -1j) for i in range(N)] | ||
entries += [(i * 1j, 1) for i in range(M)] | ||
entries += [(N - 1 + i * 1j, -1) for i in range(M)] | ||
print(max(energized(*x) for x in entries)) |