simplify RumbleBot

This commit is contained in:
Your Average Code 2024-01-25 21:26:53 +01:00
parent 13955b7b29
commit 59514963eb
2 changed files with 12 additions and 26 deletions

View File

@ -46,6 +46,7 @@ public abstract class Bot implements Runnable {
protected void print(View view) { protected void print(View view) {
view.print(); view.print();
System.out.println();
} }
// Diese Methode ermittelt den nächsten Zug des Bots. Sie wird von der // Diese Methode ermittelt den nächsten Zug des Bots. Sie wird von der

View File

@ -28,18 +28,14 @@ public class RumbleBot extends Bot {
@Override @Override
protected char nextMove(View view) { protected char nextMove(View view) {
System.out.println();
int size = view.width; int size = view.width;
String data = view.data; String data = view.data;
char[][] grid = dataToGrid(data, size); char[][] grid = dataToGrid(data, size);
if (data.contains("v") || data.contains("^") || data.contains("<") || data.contains(">")) { if (isInLineOfSight(grid)) {
if (isInLineOfSight(grid)) { return 'f';
return 'f'; } else if (data.contains("v") || data.contains("^") || data.contains("<") || data.contains(">")) {
} else { return breadthFirstSearch(grid);
return breadthFirstSearch(grid);
}
} else { } else {
return walkAround(grid); return walkAround(grid);
} }
@ -96,34 +92,23 @@ public class RumbleBot extends Bot {
protected boolean isInLineOfSight(char[][] grid) { protected boolean isInLineOfSight(char[][] grid) {
int size = grid.length; int size = grid.length;
for (int y = size / 2; y >= 0; y--) { for (int y = size / 2; y >= 0; y--) {
if (obstacles.contains("" + grid[size / 2][y]))
break;
if (players.contains("" + grid[size / 2][y])) if (players.contains("" + grid[size / 2][y]))
return true; return true;
if (obstacles.contains("" + grid[size / 2][y]))
break;
} }
return false; return false;
} }
protected char walkAround(char[][] grid) { protected char walkAround(char[][] grid) {
int size = grid.length;
if (steps == 0) { if (steps == 0) {
steps = random.nextInt(20); steps = random.nextInt(20);
if(random.nextBoolean()) return random.nextBoolean() ? '<' : '>';
return '<';
else
return '>';
} else { } else {
steps--; steps--;
return safeMove(grid); return obstacles.contains("" + grid[size / 2][size / 2 - 1]) ? '<' : '^';
}
}
protected char safeMove(char[][] grid) {
int size = grid.length;
if (obstacles.contains("" + grid[size / 2][size / 2 - 1])) {
return '<';
} else {
return '^';
} }
} }
@ -159,7 +144,7 @@ public class RumbleBot extends Bot {
} }
System.err.println("No path found"); System.err.println("No path found");
return safeMove(grid); return walkAround(grid);
} }
protected record Move(int x, int y, char direction) { protected record Move(int x, int y, char direction) {