From 8c40d7bacb5c49ce587426f97d487a82c836ce0a Mon Sep 17 00:00:00 2001 From: Your Average Code <138674451+UrAvgCode@users.noreply.github.com> Date: Thu, 25 Jan 2024 15:49:53 +0100 Subject: [PATCH] RumbleBot markFiringLines --- src/RumbleBot.java | 48 +++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 45 insertions(+), 3 deletions(-) diff --git a/src/RumbleBot.java b/src/RumbleBot.java index b998e90..d8b643b 100644 --- a/src/RumbleBot.java +++ b/src/RumbleBot.java @@ -47,11 +47,52 @@ public class RumbleBot extends Bot { for (int i = 0; i < data.length(); i++) { grid[i % size][i / size] = data.charAt(i); } - return markFiringLines(grid); + return grid; } - protected char[][] markFiringLines(char[][] grid) { - return grid; + protected void markFiringLines(char[][] grid) { + int size = grid.length; + for (int x = 0; x < size; x++) { + for (int y = 0; y < size; y++) { + + if (grid[x][y] == 'v') { + int scanY = y; + while (scanY < size && !obstacles.contains("" + grid[x][y])) { + if (grid[x][scanY] == '.') + grid[x][scanY] = '*'; + scanY++; + } + } + + if (grid[x][y] == '^') { + int scanY = y; + while (scanY >= 0 && !obstacles.contains("" + grid[x][y])) { + if (grid[x][scanY] == '.') + grid[x][scanY] = '*'; + scanY--; + } + } + + if (grid[x][y] == '>') { + int scanX = x; + while (scanX < size && !obstacles.contains("" + grid[x][y])) { + if (grid[scanX][y] == '.') + grid[scanX][y] = '*'; + scanX++; + } + } + + if (grid[x][y] == '<') { + int scanX = x; + while (scanX >= 0 && !obstacles.contains("" + grid[x][y])) { + if (grid[scanX][y] == '.') + grid[scanX][y] = '*'; + scanX--; + } + } + + } + } } protected boolean isInLineOfSight(char[][] grid) { @@ -91,6 +132,7 @@ public class RumbleBot extends Bot { } protected char breadthFirstSearch(char[][] grid) { + markFiringLines(grid); int size = grid.length; int start = size / 2;