day 15 puzzle 1
This commit is contained in:
		
							
								
								
									
										
											BIN
										
									
								
								progress.png
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								progress.png
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 123 KiB After Width: | Height: | Size: 124 KiB | 
| @@ -26,3 +26,5 @@ | |||||||
|   stars: 2 |   stars: 2 | ||||||
| 14: | 14: | ||||||
|   stars: 2 |   stars: 2 | ||||||
|  | 15: | ||||||
|  |   stars: 1 | ||||||
							
								
								
									
										10
									
								
								res/examples/day15_1.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								res/examples/day15_1.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | ######## | ||||||
|  | #..O.O.# | ||||||
|  | ##@.O..# | ||||||
|  | #...O..# | ||||||
|  | #.#.O..# | ||||||
|  | #...O..# | ||||||
|  | #......# | ||||||
|  | ######## | ||||||
|  |  | ||||||
|  | <^^>>>vv<v>>v<< | ||||||
							
								
								
									
										21
									
								
								res/examples/day15_2.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								res/examples/day15_2.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | ########## | ||||||
|  | #..O..O.O# | ||||||
|  | #......O.# | ||||||
|  | #.OO..O.O# | ||||||
|  | #..O@..O.# | ||||||
|  | #O#..O...# | ||||||
|  | #O..O..O.# | ||||||
|  | #.OO.O.OO# | ||||||
|  | #....O...# | ||||||
|  | ########## | ||||||
|  |  | ||||||
|  | <vv>^<v^>v>^vv^v>v<>v^v<v<^vv<<<^><<><>>v<vvv<>^v^>^<<<><<v<<<v^vv^v>^ | ||||||
|  | vvv<<^>^v^^><<>>><>^<<><^vv^^<>vvv<>><^^v>^>vv<>v<<<<v<^v>^<^^>>>^<v<v | ||||||
|  | ><>vv>v^v^<>><>>>><^^>vv>v<^^^>>v^v^<^^>v^^>v^<^v>v<>>v^v^<v>v^^<^^vv< | ||||||
|  | <<v<^>>^^^^>>>v^<>vvv^><v<<<>^^^vv^<vvv>^>v<^^^^v<>^>vvvv><>>v^<<^^^^^ | ||||||
|  | ^><^><>>><>^^<<^^v>>><^<v>^<vv>>v>>>^v><>^v><<<<v>>v<v<v>vvv>^<><<>^>< | ||||||
|  | ^>><>^v<><^vvv<^^<><v<<<<<><^v<<<><<<^^<v<^^^><^>>^<v^><<<^>>^v<v^v<v^ | ||||||
|  | >^>>^v>vv>^<<^v<>><<><<v<<v><>v<^vv<<<>^^v^>^^>>><<^v>>v^v><^^>>^<>vv^ | ||||||
|  | <><^^>^^^<><vvvvv^v<v<<>^v<v>v<<^><<><<><<<^^<<<^<<>><<><^^^>^^<>^>v<> | ||||||
|  | ^^>vv<^v^v<vv>^<><v<^v>^^^>>>^^vvv^>vvv<>>>^<^>>>>>^<<^v>^vvv<>^<><<v> | ||||||
|  | v^^>>><<^^<>>^v^<v^vv<>v^<<>^<^v^v><^<<<><<^<v><v<>vv>>v><v^<vv<>v^<<^ | ||||||
							
								
								
									
										91
									
								
								src/day15/puzzle1.typ
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								src/day15/puzzle1.typ
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | #import "/src/utils.typ": * | ||||||
|  |  | ||||||
|  | #let WALL = "#" | ||||||
|  | #let BOX = "O" | ||||||
|  | #let BOT = "@" | ||||||
|  | #let EMPTY = "." | ||||||
|  |  | ||||||
|  | #let offsets = ( | ||||||
|  |   "^": (0, -1), | ||||||
|  |   "<": (-1, 0), | ||||||
|  |   "v": (0, 1), | ||||||
|  |   ">": (1, 0) | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | #let compute-value(grid) = { | ||||||
|  |   let total = 0 | ||||||
|  |   for (y, row) in grid.enumerate() { | ||||||
|  |     for (x, type) in row.enumerate() { | ||||||
|  |       if type == BOX { | ||||||
|  |         total += y * 100 + x | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return total | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #let solve(input) = { | ||||||
|  |   let (grid-data, move-data) = input.split("\n\n") | ||||||
|  |   let grid = grid-data.split("\n").map(r => r.clusters()) | ||||||
|  |   let rows = () | ||||||
|  |   let cols = () | ||||||
|  |    | ||||||
|  |   let w = grid.first().len() | ||||||
|  |   let h = grid.len() | ||||||
|  |   let bot-pos = none | ||||||
|  |  | ||||||
|  |   for y in range(h) { | ||||||
|  |     for x in range(w) { | ||||||
|  |       let type = grid.at(y).at(x) | ||||||
|  |       if type == BOT { | ||||||
|  |         bot-pos = (x, y) | ||||||
|  |         grid.at(y).at(x) = EMPTY | ||||||
|  |         break | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     if bot-pos != none { | ||||||
|  |       break | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   let (bot-x, bot-y) = bot-pos | ||||||
|  |  | ||||||
|  |   let moves = move-data.replace("\n", "").clusters() | ||||||
|  |   for (move-i, move) in moves.enumerate() { | ||||||
|  |     let (dx, dy) = offsets.at(move) | ||||||
|  |     let (x2, y2) = (bot-x + dx, bot-y + dy) | ||||||
|  |     let type = grid.at(y2).at(x2) | ||||||
|  |     if type == WALL { | ||||||
|  |       continue | ||||||
|  |     } | ||||||
|  |     if type == EMPTY { | ||||||
|  |       (bot-x, bot-y) = (x2, y2) | ||||||
|  |       continue | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     let type2 = type | ||||||
|  |     let (x3, y3) = (x2, y2) | ||||||
|  |     while type2 == BOX { | ||||||
|  |       x3 += dx | ||||||
|  |       y3 += dy | ||||||
|  |       type2 = grid.at(y3).at(x3) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if type2 == WALL { | ||||||
|  |       continue | ||||||
|  |     } | ||||||
|  |     grid.at(y3).at(x3) = BOX | ||||||
|  |     grid.at(y2).at(x2) = EMPTY | ||||||
|  |     (bot-x, bot-y) = (x2, y2) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return compute-value(grid) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #show-puzzle( | ||||||
|  |   15, 1, | ||||||
|  |   solve, | ||||||
|  |   example: ( | ||||||
|  |     "1": 2028, | ||||||
|  |     "2": 10092 | ||||||
|  |   ) | ||||||
|  | ) | ||||||
							
								
								
									
										0
									
								
								src/day15/puzzle2.typ
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								src/day15/puzzle2.typ
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/main.pdf
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/main.pdf
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
		Reference in New Issue
	
	Block a user