summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--day16/day16.java73
1 files changed, 44 insertions, 29 deletions
diff --git a/day16/day16.java b/day16/day16.java
index ce07fda..f03dcd6 100644
--- a/day16/day16.java
+++ b/day16/day16.java
@@ -23,12 +23,10 @@ public class day16 {
LinkedList<Beam> beams = new LinkedList<>();
beams.add(new Beam(0, 0, Dir.Right, grid));
- int count = 500000;
- while (beams.size() > 0 && count > 0) {
+ while (beams.size() > 0) {
Beam beam = beams.remove();
LinkedList<Beam> splits = beam.stepThrough();
beams.addAll(splits);
- count -= 1;
}
return Integer.toString(grid.visited());
@@ -56,15 +54,21 @@ public class day16 {
private static class Cell {
Tile tile;
boolean visited;
+ boolean canBlackhole;
public Cell(Tile tile) {
this.tile = tile;
this.visited = false;
+ this.canBlackhole = false;
}
public void visit() {
this.visited = true;
}
+
+ public void doSplit() {
+ this.canBlackhole = true;
+ }
}
private static class Grid {
@@ -145,6 +149,7 @@ public class day16 {
public LinkedList<Beam> stepThrough() {
LinkedList<Beam> splits = new LinkedList<>();
+steppingLoop:
while (!this.escaped()) {
Cell cell = this.grid.cellAt(this.row, this.col);
cell.visit();
@@ -190,35 +195,45 @@ public class day16 {
}
break;
case VSplitter:
- switch (this.dir) {
- case Right:
- case Left:
- splits.add(new Beam(this.row + 1, this.col, Dir.Down, this.grid));
- this.dir = Dir.Up;
- this.row -= 1;
- break;
- case Up:
- this.row -= 1;
- break;
- case Down:
- this.row += 1;
- break;
+ if (!cell.canBlackhole) {
+ switch (this.dir) {
+ case Right:
+ case Left:
+ cell.doSplit();
+ splits.add(new Beam(this.row + 1, this.col, Dir.Down, this.grid));
+ this.dir = Dir.Up;
+ this.row -= 1;
+ break;
+ case Up:
+ this.row -= 1;
+ break;
+ case Down:
+ this.row += 1;
+ break;
+ }
+ } else {
+ break steppingLoop;
}
break;
case HSplitter:
- switch (this.dir) {
- case Right:
- this.col += 1;
- break;
- case Left:
- this.col -= 1;
- break;
- case Up:
- case Down:
- splits.add(new Beam(this.row, this.col + 1, Dir.Right, this.grid));
- this.dir = Dir.Left;
- this.col -= 1;
- break;
+ if (!cell.canBlackhole) {
+ switch (this.dir) {
+ case Right:
+ this.col += 1;
+ break;
+ case Left:
+ this.col -= 1;
+ break;
+ case Up:
+ case Down:
+ cell.doSplit();
+ splits.add(new Beam(this.row, this.col + 1, Dir.Right, this.grid));
+ this.dir = Dir.Left;
+ this.col -= 1;
+ break;
+ }
+ } else {
+ break steppingLoop;
}
break;
default: