d16
This commit is contained in:
		
							
								
								
									
										160
									
								
								day16/d16p1.debug.swift
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										160
									
								
								day16/d16p1.debug.swift
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,160 @@ | |||||||
|  | import Foundation | ||||||
|  |  | ||||||
|  | typealias CellCost = (cell: Cell, cost: Int) | ||||||
|  |  | ||||||
|  | enum Dir : String, CaseIterable, CustomStringConvertible { | ||||||
|  |     case n = "▲" | ||||||
|  |     case s = "▼" | ||||||
|  |     case e = "▶" | ||||||
|  |     case w = "◀" | ||||||
|  |     var description: String { return self.rawValue } | ||||||
|  |     func turnCost(to dir: Self) -> Int? { | ||||||
|  |         if self == dir { return 0 } | ||||||
|  |         if (self == .n && dir == .s) || (self == .s && dir == .n) || | ||||||
|  |            (self == .e && dir == .w) || (self == .w && dir == .e) { return nil } | ||||||
|  |         return 1000 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct Cell : Hashable, CustomStringConvertible { | ||||||
|  |     let (i, j): (Int, Int) | ||||||
|  |     let dir: Dir | ||||||
|  |     var description: String { return "(\(i),\(j))\(dir)" } | ||||||
|  |     func neighbor(_ dir: Dir) -> CellCost? { | ||||||
|  |         if let cost = self.dir.turnCost(to: dir) { | ||||||
|  |             let c = cost + 1 | ||||||
|  |             switch dir { | ||||||
|  |             case Dir.n: return (cell: Cell(i: i-1, j: j, dir: dir), cost: c) | ||||||
|  |             case Dir.s: return (cell: Cell(i: i+1, j: j, dir: dir), cost: c) | ||||||
|  |             case Dir.e: return (cell: Cell(i: i, j: j+1, dir: dir), cost: c) | ||||||
|  |             case Dir.w: return (cell: Cell(i: i, j: j-1, dir: dir), cost: c) | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             return nil | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct QueueEntry : Hashable, CustomStringConvertible { | ||||||
|  |     let cell: Cell | ||||||
|  |     let origin: Cell | ||||||
|  |     let costSoFar: Int | ||||||
|  |     var description: String { return "\(cell) from \(origin) @\(costSoFar)" } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct IJ : Hashable {  //TODO: delete | ||||||
|  |     let i: Int | ||||||
|  |     let j: Int | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct CellPair : Hashable { | ||||||
|  |     let a: Cell | ||||||
|  |     let b: Cell | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct Maze : CustomStringConvertible { | ||||||
|  |     let walls: [[Bool]] | ||||||
|  |     let (w, h): (Int, Int) | ||||||
|  |     var start: Cell { return Cell(i: h-2, j: 1, dir: Dir.e) } | ||||||
|  |     var ends: Set<Cell> { | ||||||
|  |         return Set(Dir.allCases.map { Cell(i: 1, j: w-2, dir: $0) }) | ||||||
|  |     } | ||||||
|  |     var description: String { | ||||||
|  |         return "┌" + String(repeating: "─", count: w*2) + "┐\n" + | ||||||
|  |             walls.map { | ||||||
|  |                 "│" + $0.map { $0 ? "██" : "  " }.joined() + "│" | ||||||
|  |             }.joined(separator: "\n") + | ||||||
|  |             "\n└" + String(repeating: "─", count: w*2) + "┘" | ||||||
|  |     } | ||||||
|  |     init(fromFile f: String) throws { | ||||||
|  |         let content = try String(contentsOfFile: f, encoding: .ascii) | ||||||
|  |         let lines = content.split(separator: "\n") | ||||||
|  |         (h, w) = (lines.count, lines[0].count) | ||||||
|  |         walls = lines.map { line in line.map { cell in cell == "#" } } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func neighbors(of cell: Cell) -> [CellCost] { | ||||||
|  |         return Dir.allCases | ||||||
|  |             .compactMap { cell.neighbor($0) } | ||||||
|  |             .filter { nb in !walls[nb.cell.i][nb.cell.j] } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func graph() -> [Cell:[CellCost]] { | ||||||
|  |         var edges: [Cell:[(Cell, Int)]] = [start: []] | ||||||
|  |         var q: [QueueEntry] = [ | ||||||
|  |             QueueEntry(cell: start, origin: start, costSoFar: 0) | ||||||
|  |         ] | ||||||
|  |         var seen: Set<CellPair> = [] | ||||||
|  |         while !q.isEmpty { | ||||||
|  |             let e = q.removeLast() | ||||||
|  |             var origin = e.origin | ||||||
|  |             var costSoFar = e.costSoFar | ||||||
|  |             let nbs = neighbors(of: e.cell) | ||||||
|  |             //xprint(q: q, cell: e.cell) | ||||||
|  |             //print("q: \(q)") | ||||||
|  |             //print("c: \(e.cell) -> \(nbs)") | ||||||
|  |             if ends.contains(e.cell) || (nbs.count > 1 && e.cell != start) { | ||||||
|  |                 if seen.contains(CellPair(a: origin, b: e.cell)) { | ||||||
|  |                     continue | ||||||
|  |                 } | ||||||
|  |                 let upd = edges[origin, default: []] + [(e.cell, costSoFar)] | ||||||
|  |                 edges[origin] = upd | ||||||
|  |                 seen.insert(CellPair(a: origin, b: e.cell)) | ||||||
|  |                 origin = e.cell | ||||||
|  |                 costSoFar = 0 | ||||||
|  |                 //print("!!!! \(e.cell)") | ||||||
|  |                 //edges.forEach { k, v in print(" - \(k): \(v)") } | ||||||
|  |             } | ||||||
|  |             if !ends.contains(e.cell) { | ||||||
|  |                 nbs.map { cell, cost in | ||||||
|  |                     QueueEntry( | ||||||
|  |                         cell: cell, origin: origin, costSoFar: costSoFar + cost | ||||||
|  |                     ) | ||||||
|  |                 }.forEach { q.append($0) } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         ends.forEach { edges[$0] = [] } | ||||||
|  |         return edges | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func xprint(q: [QueueEntry], cell: Cell) { | ||||||
|  |         let qx = Set(q.map { IJ(i: $0.cell.i, j: $0.cell.j) }) | ||||||
|  |         let s: [[String]] = walls.enumerated().map { i, r in | ||||||
|  |             [String(format: "%02d ", i)] + r.enumerated().map { j, c in | ||||||
|  |                 if c { return "██" } | ||||||
|  |                 if cell.i == i && cell.j == j { return "🯇🯈" } | ||||||
|  |                 if qx.contains(IJ(i: i, j: j)) { return "▒▒" } | ||||||
|  |                 return "  " | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         print("    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4") | ||||||
|  |         print(s.map { $0.joined() }.joined(separator: "\n")) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func search() -> Int { | ||||||
|  |         let edges = graph() | ||||||
|  |         edges.forEach { k, v in print(" - \(k): \(v)") } | ||||||
|  |  | ||||||
|  |         var q: [CellCost] = [(cell: start, cost: 0)] | ||||||
|  |         var visited: [Cell:Int] = [:] | ||||||
|  |         while !q.isEmpty { | ||||||
|  |             let e = q.removeLast() | ||||||
|  |             print("visiting \(e)") | ||||||
|  |             for (cell, cost) in edges[e.cell]! { | ||||||
|  |                 if let prevCost = visited[cell] { | ||||||
|  |                     if e.cost + cost >= prevCost { | ||||||
|  |                         continue | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 visited[cell] = e.cost + cost | ||||||
|  |                 q.append((cell: cell, cost: e.cost + cost)) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         print(visited) | ||||||
|  |         return ends.compactMap { visited[$0] }.min()! | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | let maze = try Maze(fromFile: CommandLine.arguments[1]) | ||||||
|  | print(maze) | ||||||
|  | print(maze.search()) | ||||||
							
								
								
									
										136
									
								
								day16/d16p1.swift
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								day16/d16p1.swift
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,136 @@ | |||||||
|  | import Foundation | ||||||
|  |  | ||||||
|  | typealias CellCost = (cell: Cell, cost: Int) | ||||||
|  |  | ||||||
|  | enum Dir : String, CaseIterable, CustomStringConvertible { | ||||||
|  |     case n = "▲" | ||||||
|  |     case s = "▼" | ||||||
|  |     case e = "▶" | ||||||
|  |     case w = "◀" | ||||||
|  |     var description: String { return self.rawValue } | ||||||
|  |     func turnCost(to dir: Self) -> Int? { | ||||||
|  |         if self == dir { return 0 } | ||||||
|  |         if (self == .n && dir == .s) || (self == .s && dir == .n) || | ||||||
|  |            (self == .e && dir == .w) || (self == .w && dir == .e) { return nil } | ||||||
|  |         return 1000 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct Cell : Hashable, CustomStringConvertible { | ||||||
|  |     let (i, j): (Int, Int) | ||||||
|  |     let dir: Dir | ||||||
|  |     var description: String { return "(\(i),\(j))\(dir)" } | ||||||
|  |     func neighbor(_ dir: Dir) -> CellCost? { | ||||||
|  |         if let cost = self.dir.turnCost(to: dir) { | ||||||
|  |             let c = cost + 1 | ||||||
|  |             switch dir { | ||||||
|  |             case Dir.n: return (cell: Cell(i: i-1, j: j, dir: dir), cost: c) | ||||||
|  |             case Dir.s: return (cell: Cell(i: i+1, j: j, dir: dir), cost: c) | ||||||
|  |             case Dir.e: return (cell: Cell(i: i, j: j+1, dir: dir), cost: c) | ||||||
|  |             case Dir.w: return (cell: Cell(i: i, j: j-1, dir: dir), cost: c) | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             return nil | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct QueueEntry : Hashable, CustomStringConvertible { | ||||||
|  |     let cell: Cell | ||||||
|  |     let origin: Cell | ||||||
|  |     let costSoFar: Int | ||||||
|  |     var description: String { return "\(cell) from \(origin) @\(costSoFar)" } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct CellPair : Hashable { | ||||||
|  |     let a: Cell | ||||||
|  |     let b: Cell | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct Maze : CustomStringConvertible { | ||||||
|  |     let walls: [[Bool]] | ||||||
|  |     let (w, h): (Int, Int) | ||||||
|  |     var start: Cell { return Cell(i: h-2, j: 1, dir: Dir.e) } | ||||||
|  |     var ends: Set<Cell> { | ||||||
|  |         return Set(Dir.allCases.map { Cell(i: 1, j: w-2, dir: $0) }) | ||||||
|  |     } | ||||||
|  |     var description: String { | ||||||
|  |         let s: [[String]] = walls.enumerated().map { i, r in | ||||||
|  |             [String(format: "%3d ", i)] + r.map { $0 ? "██" : "  " } | ||||||
|  |         } | ||||||
|  |         print("    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4") | ||||||
|  |         return s.map { $0.joined() }.joined(separator: "\n") | ||||||
|  |     } | ||||||
|  |     init(fromFile f: String) throws { | ||||||
|  |         let content = try String(contentsOfFile: f, encoding: .ascii) | ||||||
|  |         let lines = content.split(separator: "\n") | ||||||
|  |         (h, w) = (lines.count, lines[0].count) | ||||||
|  |         walls = lines.map { line in line.map { cell in cell == "#" } } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func neighbors(of cell: Cell) -> [CellCost] { | ||||||
|  |         return Dir.allCases | ||||||
|  |             .compactMap { cell.neighbor($0) } | ||||||
|  |             .filter { nb in !walls[nb.cell.i][nb.cell.j] } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func graph() -> [Cell:[CellCost]] { | ||||||
|  |         var edges: [Cell:[(Cell, Int)]] = [start: []] | ||||||
|  |         var q: [QueueEntry] = [ | ||||||
|  |             QueueEntry(cell: start, origin: start, costSoFar: 0) | ||||||
|  |         ] | ||||||
|  |         var seen: Set<CellPair> = [] | ||||||
|  |         while !q.isEmpty { | ||||||
|  |             let e = q.removeLast() | ||||||
|  |             var origin = e.origin | ||||||
|  |             var costSoFar = e.costSoFar | ||||||
|  |             let nbs = neighbors(of: e.cell) | ||||||
|  |             if ends.contains(e.cell) || (nbs.count > 1 && e.cell != start) { | ||||||
|  |                 if seen.contains(CellPair(a: origin, b: e.cell)) { | ||||||
|  |                     continue | ||||||
|  |                 } | ||||||
|  |                 let upd = edges[origin, default: []] + [(e.cell, costSoFar)] | ||||||
|  |                 edges[origin] = upd | ||||||
|  |                 seen.insert(CellPair(a: origin, b: e.cell)) | ||||||
|  |                 origin = e.cell | ||||||
|  |                 costSoFar = 0 | ||||||
|  |             } | ||||||
|  |             if !ends.contains(e.cell) { | ||||||
|  |                 nbs.map { cell, cost in | ||||||
|  |                     QueueEntry( | ||||||
|  |                         cell: cell, origin: origin, costSoFar: costSoFar + cost | ||||||
|  |                     ) | ||||||
|  |                 }.forEach { q.append($0) } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         ends.forEach { edges[$0] = [] } | ||||||
|  |         return edges | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func search() -> Int { | ||||||
|  |         let edges = graph() | ||||||
|  |         // edges.forEach { k, v in print(" - \(k): \(v)") } | ||||||
|  |  | ||||||
|  |         var q: [CellCost] = [(cell: start, cost: 0)] | ||||||
|  |         var visited: [Cell:Int] = [:] | ||||||
|  |         while !q.isEmpty { | ||||||
|  |             let e = q.removeLast() | ||||||
|  |             if let node = edges[e.cell] { | ||||||
|  |                 for (cell, cost) in node { | ||||||
|  |                     if let prevCost = visited[cell] { | ||||||
|  |                         if e.cost + cost >= prevCost { | ||||||
|  |                             continue | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     visited[cell] = e.cost + cost | ||||||
|  |                     q.append((cell: cell, cost: e.cost + cost)) | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return ends.compactMap { visited[$0] }.min()! | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | let maze = try Maze(fromFile: CommandLine.arguments[1]) | ||||||
|  | // print(maze) | ||||||
|  | print(maze.search()) | ||||||
							
								
								
									
										163
									
								
								day16/d16p2.swift
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										163
									
								
								day16/d16p2.swift
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,163 @@ | |||||||
|  | import Foundation | ||||||
|  |  | ||||||
|  | typealias CellCost = (cell: Cell, cost: Int) | ||||||
|  |  | ||||||
|  | enum Dir : String, CaseIterable, CustomStringConvertible { | ||||||
|  |     case n = "▲" | ||||||
|  |     case s = "▼" | ||||||
|  |     case e = "▶" | ||||||
|  |     case w = "◀" | ||||||
|  |     var description: String { return self.rawValue } | ||||||
|  |     func turnCost(to dir: Self) -> Int? { | ||||||
|  |         if self == dir { return 0 } | ||||||
|  |         if (self == .n && dir == .s) || (self == .s && dir == .n) || | ||||||
|  |            (self == .e && dir == .w) || (self == .w && dir == .e) { return nil } | ||||||
|  |         return 1000 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct Cell : Hashable, CustomStringConvertible { | ||||||
|  |     let (i, j): (Int, Int) | ||||||
|  |     let dir: Dir | ||||||
|  |     var description: String { return "(\(i),\(j))\(dir)" } | ||||||
|  |     func neighbor(_ dir: Dir) -> CellCost? { | ||||||
|  |         if let cost = self.dir.turnCost(to: dir) { | ||||||
|  |             let c = cost + 1 | ||||||
|  |             switch dir { | ||||||
|  |             case Dir.n: return (cell: Cell(i: i-1, j: j, dir: dir), cost: c) | ||||||
|  |             case Dir.s: return (cell: Cell(i: i+1, j: j, dir: dir), cost: c) | ||||||
|  |             case Dir.e: return (cell: Cell(i: i, j: j+1, dir: dir), cost: c) | ||||||
|  |             case Dir.w: return (cell: Cell(i: i, j: j-1, dir: dir), cost: c) | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             return nil | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct QueueEntry : Hashable, CustomStringConvertible { | ||||||
|  |     let cell: Cell | ||||||
|  |     let origin: Cell | ||||||
|  |     let costSoFar: Int | ||||||
|  |     let path: [Cell] | ||||||
|  |     var description: String { return "\(cell) from \(origin) @\(costSoFar)" } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct CellPair : Hashable, CustomStringConvertible { | ||||||
|  |     let a: Cell | ||||||
|  |     let b: Cell | ||||||
|  |     var description: String { return "\(a),\(b)" } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | struct Maze : CustomStringConvertible { | ||||||
|  |     let walls: [[Bool]] | ||||||
|  |     let (w, h): (Int, Int) | ||||||
|  |     var start: Cell { return Cell(i: h-2, j: 1, dir: Dir.e) } | ||||||
|  |     var ends: Set<Cell> { | ||||||
|  |         return Set(Dir.allCases.map { Cell(i: 1, j: w-2, dir: $0) }) | ||||||
|  |     } | ||||||
|  |     var description: String { | ||||||
|  |         let s: [[String]] = walls.enumerated().map { i, r in | ||||||
|  |             [String(format: "%3d ", i)] + r.map { $0 ? "██" : "  " } | ||||||
|  |         } | ||||||
|  |         print("    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4") | ||||||
|  |         return s.map { $0.joined() }.joined(separator: "\n") | ||||||
|  |     } | ||||||
|  |     init(fromFile f: String) throws { | ||||||
|  |         let content = try String(contentsOfFile: f, encoding: .ascii) | ||||||
|  |         let lines = content.split(separator: "\n") | ||||||
|  |         (h, w) = (lines.count, lines[0].count) | ||||||
|  |         walls = lines.map { line in line.map { cell in cell == "#" } } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func neighbors(of cell: Cell) -> [CellCost] { | ||||||
|  |         return Dir.allCases | ||||||
|  |             .compactMap { cell.neighbor($0) } | ||||||
|  |             .filter { nb in !walls[nb.cell.i][nb.cell.j] } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     func graph() -> ([Cell:[CellCost]], [CellPair:[Cell]]) { | ||||||
|  |         var edges: [Cell:[CellCost]] = [start: []] | ||||||
|  |         var q: [QueueEntry] = [ | ||||||
|  |             QueueEntry(cell: start, origin: start, costSoFar: 0, path: [start]) | ||||||
|  |         ] | ||||||
|  |         var seen: [CellPair:[Cell]] = [:] | ||||||
|  |         while !q.isEmpty { | ||||||
|  |             let e = q.removeLast() | ||||||
|  |             var origin = e.origin | ||||||
|  |             var costSoFar = e.costSoFar | ||||||
|  |             var path = e.path | ||||||
|  |             let nbs = neighbors(of: e.cell) | ||||||
|  |             if ends.contains(e.cell) || (nbs.count > 1 && e.cell != start) { | ||||||
|  |                 if let _ = seen[CellPair(a: origin, b: e.cell)] { | ||||||
|  |                     continue | ||||||
|  |                 } | ||||||
|  |                 let upd = edges[origin, default: []] + [(e.cell, costSoFar)] | ||||||
|  |                 edges[origin] = upd | ||||||
|  |                 seen[CellPair(a: origin, b: e.cell)] = path | ||||||
|  |                 origin = e.cell | ||||||
|  |                 costSoFar = 0 | ||||||
|  |                 path = [] | ||||||
|  |             } | ||||||
|  |             if !ends.contains(e.cell) { | ||||||
|  |                 nbs.map { cell, cost in | ||||||
|  |                     QueueEntry( | ||||||
|  |                         cell: cell, origin: origin, costSoFar: costSoFar + cost, | ||||||
|  |                         path: path + [cell] | ||||||
|  |                     ) | ||||||
|  |                 }.forEach { q.append($0) } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         ends.forEach { edges[$0] = [] } | ||||||
|  |         return (edges, seen) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func search(graph edges: [Cell:[CellCost]], start: Cell) -> [Cell:(Int, [Cell])] { | ||||||
|  |     var q: [CellCost] = [(cell: start, cost: 0)] | ||||||
|  |     var visited: [Cell:(Int, [Cell])] = [:] | ||||||
|  |     while !q.isEmpty { | ||||||
|  |         let e = q.removeLast() | ||||||
|  |         if let node = edges[e.cell] { | ||||||
|  |             for (cell, cost) in node { | ||||||
|  |                 let newCost = e.cost + cost | ||||||
|  |                 if let (prevCost, prevCells) = visited[cell] { | ||||||
|  |                     if newCost > prevCost { | ||||||
|  |                         continue | ||||||
|  |                     } | ||||||
|  |                     if newCost == prevCost { | ||||||
|  |                         visited[cell] = (newCost, prevCells + [e.cell]) | ||||||
|  |                         continue | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 visited[cell] = (newCost, [e.cell]) | ||||||
|  |                 q.append((cell: cell, cost: newCost)) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return visited | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func trace(_ visited: [Cell:(Int, [Cell])], from: Cell, to: Cell) -> [[Cell]] { | ||||||
|  |     if from == to { | ||||||
|  |         return [[from]] | ||||||
|  |     } | ||||||
|  |     return visited[from, default: (-1, [])].1.flatMap { | ||||||
|  |         trace(visited, from: $0, to: to).map { $0 + [from] } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | let maze = try Maze(fromFile: CommandLine.arguments[1]) | ||||||
|  | let (graph, pathPairs) = maze.graph() | ||||||
|  | let visited = search(graph: graph, start: maze.start) | ||||||
|  | let minCost = maze.ends.compactMap { visited[$0] }.map { $0.0 }.min()! | ||||||
|  | print("minCost: \(minCost)") | ||||||
|  | let seats = maze.ends | ||||||
|  |     .filter { visited[$0, default: (0, [])].0 == minCost } | ||||||
|  |     .flatMap { trace(visited, from: $0, to: maze.start) } | ||||||
|  |     .map { zip($0, $0.dropFirst()) } | ||||||
|  |     .map { $0.flatMap { pathPairs[CellPair(a: $0.0, b: $0.1)]! } } | ||||||
|  |     .map { $0.map { cell in Cell(i: cell.i, j: cell.j, dir: Dir.n) } } | ||||||
|  |     .flatMap { $0 } | ||||||
|  | print("seats: \(Set(seats).count)") | ||||||
							
								
								
									
										141
									
								
								day16/input.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								day16/input.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | |||||||
|  | ############################################################################################################################################# | ||||||
|  | #...#.....#.......#...........#...#.............#.......#.........#.....................#.............#.........#.....#.......#.........#..E# | ||||||
|  | #.#.#.#.###.#.###.#####.#.#.#.#.#.#.###.#######.#######.#.#####.###.#.#######.###.#.#.#.#.#.###.#####.###.#####.#.###.#.###.#.#######.#.#.#.# | ||||||
|  | #.#...................#.....#...#.#.#.#.......#.........#.....#.....#.........#...#.#.#.#.#.........#.....#...#...#...#.#...#...#.....#...#.# | ||||||
|  | ###.#.#.#.#####.#####.#.#.#######.#.#.#######.#######.#######.###########.#####.#.###.#.#.#########.#######.#.#.###.#####.#####.#.###.#####.# | ||||||
|  | #...#.#...#...#.#.#...#...#...#...#...#.....#.....#.#.#...#.............#...#...#.#...#...#.......#.....................#.#.....#...#.....#.# | ||||||
|  | #.###.#####.#.#.#.#.###.#.###.#.#####.#.###.#####.#.#.#.#.#.#####.#.###.#####.#####.#########.#.#.#####.#.#####.#.###.#.#.#.#######.#.###.#.# | ||||||
|  | #.....#...#.#.#.#...#...#...#.......#.#...#...#...#...#.#...#...#.#...#.......#.....#.........#...#.....#.....#.#.#...#...#.#.......#...#.#.# | ||||||
|  | #.#####.###.#.#.#.###.#.###.#.#######.###.#.#.#.#.#####.#####.#.#.###.###.#####.#####.#############.#####.###.#.#.###.#####.###.#####.#.#.#.# | ||||||
|  | #.......#...#...#...#...#...#.#.....#.....#...#.#.#.....#.....#...#...#...#...#.....#...#...........#.#...#.#...#...#...#.....#...#.....#...# | ||||||
|  | #####.###.#####.###.###.#.#.###.###.#######.###.#.#.#########.#.###.#######.#.#####.###.#.###########.#.###.###.###.#.#.#####.###.#.#.#.###.# | ||||||
|  | #...#.#...#.......#.......#.#...#...#.....#.#.#.#.#...#...#...#.#...#.....#.#.........#.#.....#.........#.....#.....#.#.....#.....#.#.#.#...# | ||||||
|  | #.###.#.###.###.###########.#.###.#.#.#.#.#.#.#.#####.#.#.#.###.#.#.#.###.#.#########.#.#####.#.#####.###.###.#######.#####.#######.#.#.#.### | ||||||
|  | #.....#.#.......#.......................#.#.....................#.#.#...#...#.......#.......#.#.#...#.#...#.#.#.#.........#.#.....#.#.#.#...# | ||||||
|  | #.#####.#.#####.#.#.#.#######.#.#.#.#.#.#.#.#.###.#######.#####.#.#####.#####.###.#.#######.#.###.#.#.###.#.#.#.#.#########.#.###.###.#.###.# | ||||||
|  | #.....#.#.....#...#.#.#.........#.#.#.#.....#...#.........#...#.#.........#...#.....#...#...#.#...#.#...#.#.#.#...#.....#...#...#...#.......# | ||||||
|  | #######.#####.#####.#.#####.###.#.###.###.#.#.#####.#######.#.###########.#.###.#####.###.###.#.###.###.#.#.#.#####.###.#.###.#.###.#.###.### | ||||||
|  | #.......#...#.#...#...#...#...#.#.....#...#...#...#.......#.#.#.......#...#.#.#.#...#.....#.#...#.#.#.#...#...#.....#...#.#...#.#.#...#...#.# | ||||||
|  | #.#######.#.#.###.#####.#.#.#.#.#######.#######.#.#.#######.#.#.#####.###.#.#.#.#.#.#.#####.#.#.#.#.#.#####.###.#.###.###.#.###.#.###.#.###.# | ||||||
|  | #...#...#.#.............#.#...#...#.....#...#...#...#.........#...#.#...#.#.#.....#.#.......#.....#.#.....#.....#...#.#...#...#.#.....#.....# | ||||||
|  | ###.#.#.#.#########.#.###.###.###.###.###.#.#.#.###.#.#######.###.#.###.###.#.###.#.#######.#######.#.###.#######.#.#.#.#######.#.#########.# | ||||||
|  | #...#.#...#...#.......#.........#...#.#...#.#.....#...#.....#...#.#.........#.....#.............#...#...#.#.....#.#.....#.......#.........#.# | ||||||
|  | #.#####.###.#.###############.#####.#.#.###.#####.#######.#####.#.#####################.#########.#####.#.#.#####.#####.#.#.###.#######.###.# | ||||||
|  | #.#...#.#...#.......#.....#.......#...#...#.......#.......#.....#.#...#.....#.........#...........#.....#.#.#.....#.....#.#...#.........#...# | ||||||
|  | #.#.#.###.#########.#.###.#.###.###.#.###.#.#######.#.#####.###.#.#.#.###.#.#.#####.#.#.#########.#.#.#.#.#.#.#####.#.#####.#.#.#####.###.### | ||||||
|  | #...#...#.#.....#.#.#...#...#.#.......#.....#.....#.#.....#...#.....#...#.#.#.#...#.#.#.............#...#...#.#...#.#.#...#.#.......#.#...#.# | ||||||
|  | #.#####.#.#.###.#.#.###.#####.#########.#####.###.###.#.#.###.#.#######.#.###.#.#.#.###.#############.#.#.#.#.#.###.#.#.#.#######.#.###.###.# | ||||||
|  | #.#...#.....#.....#.....#.....#.......#.....#...#...#...#...#.#.....#...#.......#.#.#...#...#.......#.#.#.#...#.#...#...#.#.....#.#.#...#...# | ||||||
|  | #.#.#.#.#########.###########.#.###.#######.###.###.#######.#.###.###.#############.#.#####.#.#####.###.#.#.###.#.#######.#.###.#.#.#.###.#.# | ||||||
|  | #.#.#.#...#...#.#.....#.....#...#.#.#.....#...#.#.#.#.......#...#.#...#.........#...#.......#.#...#...#.#.#.#...#.#.....#.#.#...#.#...#...#.# | ||||||
|  | #.#.#.#.###.#.#.#####.###.#.#.###.#.#.###.#.#.#.#.#.#.#####.###.#.#.###.#######.#.#######.###.#.#.###.#.#.#.#.#.#.#.###.#.#.#.###.#####.###.# | ||||||
|  | #.#.#.#.#...#.#.#...#.#...#.#.#...#.....#...#.....#.#.....#.#.#.#.#.#.......#...#.......#.#...#.#...#.#.#.#.#.#...#.#...#...#...#.#.....#...# | ||||||
|  | ###.#.###.###.#.#.#.#.#.###.#.#.#.#########.#######.#.###.#.#.#.###.#######.#.#######.###.#.#####.###.#.###.#.###.#.###.#######.#.#.#######.# | ||||||
|  | #...#.....#.#.#.#.#...#.#...#.#.#...#.......#.......#...#.....#.....#...#.....#.......#...#.#.....#...#.#...#.....#...#.........#.#...#...#.# | ||||||
|  | #.#########.#.#.#.#####.###.#.###.#.#.#####.#.#########.#.#########.#.#.#.###.#.#######.###.#.#.###.#.#.#.#########.#.#########.#.###.#.#.#.# | ||||||
|  | #...#.......#.#.#.#.......#.#...#.#...#.....#...........#.#...#.............#.#.#.......#.#.#.#...#...#.#.#.......#.#...#.......#.....#.#.#.# | ||||||
|  | ###.#.#####.#.#.#.#######.#.###.#.#.#####.###########.#.###.#.#.#####.#####.#.#.#.#######.#.###.#.###.#.#.###.###.#.###.#.#####.#.#####.#.#.# | ||||||
|  | #...#.....#...#.......#...#...#...#.#...#...#...#.....#.....#.#.#...#.#...#.....#.........#...#.#...#...#.....#.#.#.#.#.#.#.#...#.#.....#.#.# | ||||||
|  | #.#######.###########.#.#.###.###.#.#.#.###.#.#.#.#.#######.#.#.#.#.#.###.#.#######.#####.###.#.###.###.#####.#.#.#.#.#.#.#.#.#.###.#####.#.# | ||||||
|  | #.#.......#.........#...#...#...#.#...#...#.#.#...#.#.....#.#.......#...#.#...#.....#...#.#.#.#...#...#.#.......#.#...#...#.#.#.......#...#.# | ||||||
|  | #.#.#########.###.#.#######.###.#########.#.#.#####.#.#.#.#####.#.###.#.#.#.###.###.#.#.#.#.#.#####.#.#.#.#####.#.#######.#.#.#.#######.###.# | ||||||
|  | #.#.#.........#...#...#.....#...#.........#.#.#.....#.#.#.....#.#...........#...#.....#.#...#.....#.#.#.#.#...#.#.#.....#...#.#.....#...#.#.# | ||||||
|  | #.#.###.#########.###.#.#.###.###.###.#####.#.###.###.#.#####.###.#####.#.###.###.#####.#.#######.#.###.#.#.#.#.#.#.###.#####.#.###.#.###.#.# | ||||||
|  | #.#.....#.#.........#.#.........#.#...#.....#.....#...#.....#...#.#...#.#...#.#...#.....#.#.......#...#.#...#.#.#...#...#...#.......#.#...#.# | ||||||
|  | #.#######.#.#.#.#.###.#.#######.#.#.###.#####.#.#.#.#######.###.#.#.###.#.#.#.#.###.#######.#######.#.#.#####.#.#####.###.#.###.#####.#.###.# | ||||||
|  | #.............#.#.#...#.#.....#...#.....#...#.#.#.#.#...#.........#.....#.#...#...#.......#...#.....#.......#.#.#...#.......#.........#.....# | ||||||
|  | #.#.#.#.#####.#.#.#.###.#.###.#####.#####.#.#.#.#.#.#.###.#.#######.###.#.#.#####.#######.#.#.###########.#.#.#.#.#.###.###.#.#.#.#####.##### | ||||||
|  | #.#.#.#.#...#.#.#.#.#...#.#...#.....#...#.#.#.#.#.#.#...#.......#.#.....#...#...#...#...#.#.#...........#.....#...#...#...#.#.#.#.....#.#...# | ||||||
|  | #.#.#.#.#.#.#.#.#.#.#.###.#.###.#####.#.#.#.#.#.#.#.###.#######.#.#####.###.#.#####.###.#.#####.#######.###.#######.#.###.#.#.#.#####.#.#.#.# | ||||||
|  | #.....#...#...#...#.#...#.#...#...#...#...#...#.#.#...#.......#.....#.....#.#.....#...#.......#.#.....#...#...#.....#.....#.#.#.#.....#...#.# | ||||||
|  | #.#.#.#.#####.###.#.###.#.###.###.###.###.###.#.#####.#.#.###.#.###.#.###.#.###.#####.#######.#.#.###.###.#.#.#.###.#.#.#.#.#.#.#.#########.# | ||||||
|  | #.#.#.#.#...#.....#...#.#.#.#.#.......#...#...#.#.....#.#...#.#...#.....#.......#...#.......#.#.#...#.....#.#...#...#...#.#...#...#.........# | ||||||
|  | #.#.#.###.#.#.###.###.###.#.#.#.#######.###.###.#.#####.#.#.#.###.###.###.#######.#.#######.#.###.#.#.#####.#.#.#.#######.#####.###.######### | ||||||
|  | #.#.#.#...#...#...#...#...#...#.#...#...#...#.....#.....#...#...#...#.#...#.......#.........#...#.#.#.#...#.#...#.......#...#.....#.#.....#.# | ||||||
|  | #.###.#.#.###.#.###.###.###.#####.#.###.#.#######.#####.#.###.#####.###.###.###################.###.###.#.#.###########.###.#.#.#.#.#.#.#.#.# | ||||||
|  | #...#...#...#.#.#...#.....#.......#...#.#.......#.....#.#.#...#...#.....#...#...#...........#.....#.#...#.#...........#.....#.#.#...#.#.#.#.# | ||||||
|  | ###.#####.#.#.#.#.#.#.###.###########.#.#######.#####.###.#####.#.#######.###.#.#.#####.#.#.#.###.#.#.###.###.#######.#######.#.#######.#.#.# | ||||||
|  | #...#...#.#.#.#...#.#...#.#.......#...#...#.....#...#.....#...#.#.....#...#...#...#...#.#.#...#...#.#...#.#...#.....#.#.....#.#.........#.#.# | ||||||
|  | #.###.#.#.#.#.###.#.###.#.#.#####.#.#####.#.#######.###.#.#.#.#.#####.#.###.#########.#.#.#####.###.#.###.#####.###.###.###.#.#.#########.#.# | ||||||
|  | #.#...#.#.#...#.....#.#.#.#.#...#.#.......#.......#.#...#...#.....#...#.#.....#.......#.#.#...#.#.....#...#.....#.#.....#.#...#.............# | ||||||
|  | #.#.#.#.#.###.#.#####.#.#.#.###.#.#######.#.#####.#.#.#####.#######.###.#####.#.#####.#.#.#.#.#.#######.###.#####.#######.#######.###.#.###.# | ||||||
|  | #...#.#...#...#.#.......#.#...#.....#...#.#.....#.#.#.#...#.......#...#.....#.#.#...#.#...#.#...#.....#...#.#.#.......#.........#.#...#.....# | ||||||
|  | #.###.###.#.#.#.#########.###.#.#####.#.#.#######.#.#.#.#.#.#####.#.#.#####.#.#.#.#.#.#.###.#####.###.###.#.#.#.###.###.#.#.###.#.#.###.##### | ||||||
|  | #.#...#...#.#.............#...#.#.....#...#.......#.#...#...#...#.#.#.#.....#.#.#.#.#.#.....#.#...#.#.....#.#.#.#.#.....#...#.#.#.#.#.#...#.# | ||||||
|  | #.#.###.#.#.#.###.#.#.#####.#####.#######.#.#######.#########.###.#.#.#.#####.#.#.#.###.#.###.#.#.#.#####.#.#.#.#.###.###.###.#.#.#.#.###.#.# | ||||||
|  | #.#...#.#...#...#...#.#...#.........#...#...#.#.............#...#...#.#.#.....#...#.....#...#...#.#.....#.#.#.....#...#...#.#...#.#.#.....#.# | ||||||
|  | #.###.#######.#.#.#.###.#.###########.#.#####.#.#########.###.#.###.#.#.###.###.#####.#####.###.#.#.###.#.#.#######.#.#.###.#.###.#.#.#####.# | ||||||
|  | #.....#.......#...#.....#.#...........#.#...#...#.....#.#...#.#.....#.#...#...#.#...#.#...#...#.#.#...#...#.#.....#.#.#.#...#.......#.#.....# | ||||||
|  | #.#.###.#######.#########.#.#####.#####.#.#.#.###.###.#.###.#.#######.###.###.#.#.#.#.###.###.###.###.#####.#.###.#.#.#.#.###.#.#####.#.##### | ||||||
|  | #.#.....#.....#.#.#.....#...#...#...#...#.#.#.#...#.#...#.#.#.........#...#...#.#.#.#.#.....#.#...#.#.#.....#...#...#.#.#.....#...#...#.....# | ||||||
|  | #.#.#######.#.#.#.#.###.###.#.#.#####.###.#.#.###.#.###.#.#.#########.#.###.###.#.#.#.#.#####.#.###.#.#.#####.#.#####.#.#####.#.#.#.#######.# | ||||||
|  | #.#.......#.#...#.#.#.#...#.#.#...#.......#.....#.#.....#.#.....#.....#.#.....#.#.#.#...#.....#.#.....#.#...#.#...#.#.......#.#.#.#.........# | ||||||
|  | #.#######.#.#####.#.#.###.#.#.###.#.#######.###.#.###.###.#####.#.#######.###.###.#.###.#.#####.#.#####.#.###.###.#.#.#####.###.#.#########.# | ||||||
|  | #...#.#...#...#...#.#...#.#.#.#...#.#.....#...#.#...#.....#.....#.......#.#...#.......#.#...#...#.#.....#.......#.#.#.......#...#.#...#...#.# | ||||||
|  | #.#.#.#.#####.#.#.#.#.###.###.#.#.#.#.###.###.#.#.#.#####.#.#.#########.#.#.###.#####.#.###.#.#####.#########.###.#.#.#.###.#.#.#.#.#.#.#.#.# | ||||||
|  | #.#.#.#...#.....#.#.#...#.....#.#...#...#.....#.#.#...#...#.#.#.........#.....#.#.#...#.#.#.#.......#.......#.#...#.#.#.#...#.#.#.#.#.#.#...# | ||||||
|  | ###.#.###.#######.#.#.#.#######.###.###.#######.#.###.#####.###.#.###.#.#.###.#.#.#.###.#.#.#####.###.#####.###.###.#.#.###.#.#.#.#.###.##### | ||||||
|  | #...#...#.......#...#.#.......#...#...#.........#...#.....#.....#...#.#.#...#.#...#.#.#...#.....#.#.....#.......#.....#...#.#.#...#...#...#.# | ||||||
|  | #.#####.#######.#.###.#####.#####.###.#.#####.###.#######.#########.#.#.#####.#.###.#.#.#######.#.###.#.#########.#######.#.#.#.#.###.###.#.# | ||||||
|  | #.#...#.......#.#...#.#...#.#...#.....#.#.........#.......#...#...#.#.#.....#...#...#...#.....#.#...#.#...#.............#.#.........#.....#.# | ||||||
|  | #.#.#.#.###.#.#.#.#.#.#.#.#.#.#.###.###.###########.#####.#.#.#.###.#.#####.#####.###.###.###.#.###.#.###.#############.#.###.#.#.#.#.#####.# | ||||||
|  | #.#.#.#.#...#.#.#.#.#.#.#...#.#.......#.#...........#.....#.#...#...#.#...#.....#.#.#...#.#.#...#.#.#.#...#.......#.......#...#...#.#.#...#.# | ||||||
|  | #.#.#.#.#.#####.#.#.###.###.#.#######.#.#.#.#########.#####.#####.###.###.#####.#.#.###.#.#.#####.#.###.###.#####.#########.#####.#.#.#.#.#.# | ||||||
|  | #...#.#.#.......#.#...#...#.#.#.....#.....#.#...#...........#.....#.#.........#...#...#.#.#...#...#.#...#...#.#...#.......#.#.#...#.#...#...# | ||||||
|  | #.#.#.#.#.#########.#.###.###.#####.#########.#.#.#########.#.#####.#####.###########.#.#.#.#.#.#.#.#.#.#.###.#.###.#####.#.#.#.#.#.#####.#.# | ||||||
|  | #...#...#.#.......#.#...#.#...#...#.....#.............#.....#...#.#.......#...........#.#.#.#.#.#.#...#...#...#.#...#...#.#.#.......#.......# | ||||||
|  | #.#.###.#.###.###.#####.#.#.###.#.#.#####.###########.###.#.###.#.#.#######.###.#######.#.#.#.#.#.#####.#.#.###.#.###.#.#.#.###.#.#.#######.# | ||||||
|  | #.#...#.#...#...#.......#...#...#.#.....#...#...#.....#...#.#.#.......#.....#.#.....#.....#.#.#.#...#.....#.....#.#...#...#...#.#.#.#.....#.# | ||||||
|  | #.###.#.###.###.#########.###.###.#####.###.#.#.#.#.#.#.###.#.#.#.#####.#####.#####.#.###.#.#.#.###.#.#.#.#.#####.#####.#####.###.#.#.###.### | ||||||
|  | #...............#.#.....#.#...#...#.......#...#.#.#.#.#.......#.#.#.....#.........#...#.#.#.#.#.........#.#.....#.....#.......#...#.#.#.#...# | ||||||
|  | #.#####.#.#######.#.###.#.#.#.###.#.#.#.#.#####.#.#.#.#####.#.#.###.#####.###.#.#.#####.#.#.#####.#######.#####.#.###.#########.#.#.#.#.###.# | ||||||
|  | #.#...#...#.....#...#.#...#.#...#.#.#.#.......#.#.#.#.#...#...#.....#...#...#.#.#.#.......#.........#...#.#.....#...#.......#...#.#.#.#.#...# | ||||||
|  | #.#.#.#.###.#.###.###.#########.#.#.#.#.#.#####.#.###.#.#.###.#######.#####.#.#.#.#####.#.#.#########.#.#.###.#########.###.#.#.###.#.#.#.#.# | ||||||
|  | #.#.#.#...#.#.#...#.....#.......#...#...#.#.....#...#.#.#.#.#.#.....#.#.....#.#.......#.#.#.#...#.....#.#...#...#.....#...#.#.#...#...#.#...# | ||||||
|  | #.#.#.#.#.###.#.#####.#.###.#############.#.#####.#.#.#.#.#.#.#.###.#.#.#.###.#.#####.#.#.###.#.#.#####.###.#.#.#.###.#####.#.###.#####.###.# | ||||||
|  | #.#.#...#...#.........#.....#.....#.....#.#.#.....#.#...#.#.#...#.....#.#.#...#.......#.#.....#...#...#.....#.#...#.#.....#.#...#.........#.# | ||||||
|  | #.###.#.###.#.###.#.#########.###.#.#####.#.#.#####.#####.#.#.#.#######.#.#.###.#######.###########.#.#######.#####.#####.#.###.#########.#.# | ||||||
|  | #...#.#.#...#.#...#...#.........#.#.......#.#.#...#.......#.#.#.#.....#.#.#.#.#.......#...........#.#.#.#.......#.......#.#.#...#.......#.#.# | ||||||
|  | #.#.#.#.#.###.#####.#.#.#########.#.###.###.###.#.###.###.#.#.#.#.###.#.#.#.#.#######.#.#########.#.#.#.#.#.#####.#.###.#.#.#.###.#####.#.#.# | ||||||
|  | #.#.#.#.#.#.......#.#.....#.......#.......#.....#.#...#...#.#.#...#...#...#.#...........#.......#.#.#...#.#.......#.#...#.#.#...#.....#.#...# | ||||||
|  | #.#.###.#.#######.#########.#.#####.#######.#####.#.#.#.###.#.#.###.###.###.#.###########.#.#.#.#.#.#.###.###.#.###.#.###.#.###.#####.#.##### | ||||||
|  | #.#.#...#.....#.......#.....#...#...#.......#...#...#.#.#.#...#.#.#.....#.....#.#...........#.......#.........#.#...#...#.#.#...#.....#.#...# | ||||||
|  | #.#.#.#.#####.#######.#.#####.#.#####.#.#.###.#.#####.#.#.#.###.#.#######.###.#.#.###########.#######.#####.#.#.#.#.#.#.#.#.#.###.#######.#.# | ||||||
|  | #.#.#.......#.....#.....#.....#.....#.#.....#.#...#...#.#...#.#.....#.#...#.....#...#.....#...#.....#.#.....#.#...#.....#...#...#.#.......#.# | ||||||
|  | #.#.#.###.#.###.#.#######.#########.#.#######.###.#####.#.###.#####.#.#.###########.#####.#.###.###.#.#.###.#.###.#.###.#######.#.#.#######.# | ||||||
|  | #...#.#.#.#.#...#.#...#...#.#.....#...#...#...#.#...#...#.#...#.....#.#.#...........#.....#...#.#.#...#.#...#.....#...#...#...#.#.#.#.....#.# | ||||||
|  | #.###.#.#.###.#.#.#.#.#.###.#.###.#####.###.###.###.#.###.#.###.#####.#.#.#########.#.#####.#.#.#.#####.#.#####.#####.###.#.###.#.#.#.###.#.# | ||||||
|  | #...#.#.#...#.#.#...#...#.....#.#.....#...#.#.....#.#.#.#.#.........#.#.......#...#...#...#.#.#.#...#...#...#...#...#.#.....#...#...#.#...#.# | ||||||
|  | ###.#.#.###.#.#.###########.###.#####.#.#.#.#.#.###.#.#.#.#########.#.#########.#.#.###.#.###.#.#.#.###.###.#.#####.#.#######.###.#####.#.#.# | ||||||
|  | #...#.#...#...#.....#.....#.........#...#.#.#.#.......#...#.......#...#.........#.#.#...#...#.#.#.#.....#.#...#.....#.......#.#.#.#...#.#.#.# | ||||||
|  | #.#.#.###.#####.###.###.#.#####.#########.#.###########.###.#####.###.#.#########.###.#####.#.#.#.#####.#.#####.###.#####.#.#.#.#.#.#.#.###.# | ||||||
|  | #...#.....#...#.#.#.#...#.#.#...#.........#.#.......#.....#.#.....#...#...#...........#.......#...#...#.........#.#.....#...#.#.....#...#...# | ||||||
|  | #.#.#####.#.#.#.#.#.#.###.#.#.###.#######.#.#.#####.#####.#.#.#####.#####.#.###.#######.#######.#.###.###########.#.###.#.###.###########.#.# | ||||||
|  | #...#.....#.#.#.#.#...#...#.#.#...#...#.#.#.#.#...#.....#...#.#...#.#.....#.....#...#...#.......#...#.......#.......#...#.....#...#.....#.#.# | ||||||
|  | ###.###.###.#.#.#.#####.###.#.#.###.#.#.#.#.#.#.###.#.#.#####.#.#.#.#.#.#####.#.#.#.#####.#########.#.#####.#.#####.#.#########.#.#.###.#.#.# | ||||||
|  | #.#...#.#.#.#...#.....#.#.....#.....#...#.#.....#...#.#...#.......#.#.#.#.....#.#.#.......#.#.......#.....#.#.#...#.#.#...#.....#...#.#.#.#.# | ||||||
|  | #.#.#.#.#.#.#####.#.###.#######.#.#.#.#.#.#####.#.#.#.###.#######.#.#.###.#####.#.#########.#.###.#######.#.#.###.#.#.#.#.###.#######.#.#.#.# | ||||||
|  | #.....#...#.....#.#.#...#.....#.#.#.#...#.......#.#.#...#...#...#.#.#.#.....#...#.......#...#.#.#.....#...#.#.....#...#.#...#.....#.......#.# | ||||||
|  | #.#.#####.#####.#.###.###.###.#.#.#.#########.###.#.#######.#.#.#.###.#.#####.#########.#.###.#.#####.#.###.#.#.#######.###.#.###.#########.# | ||||||
|  | #.....#...#...#.#...#.#.....#.....#.......#...#...#.........#.#.#...#.#.#.#...#.......#.#...#.......#.#...#.#.#.........#.#.#.#.#.....#.....# | ||||||
|  | #####.###.###.#.###.#.#.###.#####.#####.###.###.#############.#####.#.#.#.#.###.#.#####.#.#.###.#####.#####.#.#####.#.###.#.#.#.#####.###.### | ||||||
|  | #...#...#.....#.....#.#.#...#...#.....#...#.#...#.....#...........#.#.#...........#...#.#.#.....#.....#.....#.....#.#.#.....#...#...#...#...# | ||||||
|  | #.#.###.#########.#.#.###.###.###.###.###.#.#.#####.#.#.#########.#.#.###.#######.#.#.#.#.#######.###.#.#.#.###.#.###.#.#####.###.#.#.#.###.# | ||||||
|  | #.#...#...........#.#.#...#.......#.....#.#.#.....#.#.#...#...#.#.#.#.#...#.....#.#.#...#.......#.#...#.#.#.....#.....#.#...#.#...#.#.#.#.#.# | ||||||
|  | #.#.###############.#.#.###.#######.###.#.#.#####.#.#####.#.#.#.#.#.#.#.#.#.###.#.#.#####.###.###.#.###.#.#.###.#######.#.#.#.#.###.###.#.#.# | ||||||
|  | #.#.#.......#.....#...#...#.......#...#...#.......#.....#...#...#.....#.#...#...#.#.......#.#.#...#.#...#.#...#.#.....#.....#.#.............# | ||||||
|  | #.###.###.###.###.#.#####.#######.#.#.#########.#.#.#.###.###.#.#######.#.#.#.###.#######.#.#.#.#####.###.###.###.#.#######.#.#.#########.#.# | ||||||
|  | #...#.#.#.......#.#.#...#...#...#...#.......#...#.#.#.......#.#.#.......#.#.#.#...#...#...#...#...#.....#.#...#...#.......#.#.#.....#...#...# | ||||||
|  | #.#.#.#.#########.#.#.#.###.#.#####.#######.#.###.#.#.#.#.#.#.#.#.#######.#.#.#.###.#.#.#########.#.#####.#.#.#.#####.#####.#.#####.#.#.#.### | ||||||
|  | #.#.#.....#...#...................#.....#.#.#.#.#.#...#.#.#...#.#...#.....#.#.#.....#...#.......#.....#...#.#.#.#...................#.#.#...# | ||||||
|  | #.#.#####.#.###.#.###.#######.#.#.#####.#.#.#.#.#.#.#.#.#.#.###.###.#######.#.#############.###.#######.###.#.#.###.#.#.#.#.#####.#####.###.# | ||||||
|  | #.#.........#...#.#...#.......#.#.....#...#.#...#.#.#...#...#...#...#.......#.........#...#.#...........#...#.#.....#.#.#...#...#.#.....#...# | ||||||
|  | #.###########.###.#.#.#.###.###.#.#.#####.#.###.#.###.###.###.###.###.#######.#######.#.#.#.#############.#####.#####.#.#####.#.#.#.#.###.### | ||||||
|  | #...#...#.#...#...#.#.#...#.#...#.#.#.....#.#...#...#...........#.....#.......#...#...#.#.#...#...........#.....#.....#.#.....#...#.#...#.#.# | ||||||
|  | ###.#.#.#.#.###.###.#.###.#.#.###.#.#.#####.#.#####.#.###.#############.#.#.###.#.#.###.#.###.#######.#####.#####.###.#.#.###.#####.###.#.#.# | ||||||
|  | #.#...#...#.#.#.#...#.#...#...#...#.#.....#.#...#.#.#...#...#.....#.....#.#.#...#.#.....#...#.......#.#.....#...#.#...#.#...#.#...#.#.#.#...# | ||||||
|  | #.#####.###.#.#.#.###.#.#######.#.###.#####.###.#.#.#####.#.#.#.###.#####.#.#.###.#########.#.#####.#.#.#####.###.#.###.###.#.#.#.#.#.#.###.# | ||||||
|  | #.....#.#...#...#.#.#...#.....#...#...#.................#.#...........................#...#.#.#.....#.#.#.....#...#.#...#...#.#.#.#.#.#.....# | ||||||
|  | #.###.#.#.#######.#.#######.#.###.#.###.#########.#.#.#.#.#######.###.#.###.###.#####.#.#.#.#.#.#####.#.#####.#.#####.#######.#.#.#.#.####### | ||||||
|  | #S..#...#...................#...#.....#...........#...#.........#.....#.............#...#.......#.............#...............#.#...........# | ||||||
|  | ############################################################################################################################################# | ||||||
							
								
								
									
										15
									
								
								day16/test.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								day16/test.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | ############### | ||||||
|  | #.......#....E# | ||||||
|  | #.#.###.#.###.# | ||||||
|  | #.....#.#...#.# | ||||||
|  | #.###.#####.#.# | ||||||
|  | #.#.#.......#.# | ||||||
|  | #.#.#####.###.# | ||||||
|  | #...........#.# | ||||||
|  | ###.#.#####.#.# | ||||||
|  | #...#.....#.#.# | ||||||
|  | #.#.#.###.#.#.# | ||||||
|  | #.....#...#.#.# | ||||||
|  | #.###.#.#.#.#.# | ||||||
|  | #S..#.....#...# | ||||||
|  | ############### | ||||||
							
								
								
									
										17
									
								
								day16/test1.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								day16/test1.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | ################# | ||||||
|  | #...#...#...#..E# | ||||||
|  | #.#.#.#.#.#.#.#.# | ||||||
|  | #.#.#.#...#...#.# | ||||||
|  | #.#.#.#.###.#.#.# | ||||||
|  | #...#.#.#.....#.# | ||||||
|  | #.#.#.#.#.#####.# | ||||||
|  | #.#...#.#.#.....# | ||||||
|  | #.#.#####.#.###.# | ||||||
|  | #.#.#.......#...# | ||||||
|  | #.#.###.#####.### | ||||||
|  | #.#.#...#.....#.# | ||||||
|  | #.#.#.#####.###.# | ||||||
|  | #.#.#.........#.# | ||||||
|  | #.#.#.#########.# | ||||||
|  | #S#.............# | ||||||
|  | ################# | ||||||
		Reference in New Issue
	
	Block a user