mirror of
https://github.com/coding-horror/basic-computer-games.git
synced 2025-12-23 07:29:02 -08:00
267 lines
7.9 KiB
Java
267 lines
7.9 KiB
Java
import java.util.ArrayList;
|
|
import java.util.Arrays;
|
|
import java.util.Random;
|
|
import java.util.Scanner;
|
|
import static java.lang.System.in;
|
|
import static java.lang.System.out;
|
|
|
|
public class Amazing {
|
|
|
|
private final Scanner kbScanner;
|
|
|
|
public Amazing() {
|
|
kbScanner = new Scanner(in);
|
|
}
|
|
|
|
enum Direction {
|
|
GO_LEFT,
|
|
GO_UP,
|
|
GO_RIGHT,
|
|
GO_DOWN,
|
|
}
|
|
|
|
final static int FIRST_COL = 0;
|
|
final static int FIRST_ROW = 0;
|
|
|
|
final static int EXIT_UNSET = 0;
|
|
final static int EXIT_DOWN = 1;
|
|
final static int EXIT_RIGHT = 2;
|
|
|
|
public void play() {
|
|
out.println(tab(28) + "AMAZING PROGRAM");
|
|
out.println(tab(15) + "CREATIVE COMPUTING MORRISTOWN, NEW JERSEY");
|
|
out.println();
|
|
|
|
int width = 0;
|
|
int length = 0;
|
|
|
|
do {
|
|
String range = displayTextAndGetInput("WHAT ARE YOUR WIDTH AND LENGTH");
|
|
if (range.indexOf(",") > 0) {
|
|
width = getDelimitedValue(range, 0);
|
|
length = getDelimitedValue(range, 1);
|
|
}
|
|
} while (width < 1 || length < 1);
|
|
|
|
Grid grid = new Grid(length, width);
|
|
int enterCol = grid.setup();
|
|
|
|
int totalWalls = width * length + 1;
|
|
int col = enterCol;
|
|
int row = 0;
|
|
int count = 2;
|
|
|
|
Cell cell = grid.cells[row][col];
|
|
while (count != totalWalls) {
|
|
ArrayList<Direction> possibleDirs = getPossibleDirs(grid, new Cell(row, col));
|
|
|
|
if (possibleDirs.size() != 0) {
|
|
Direction direction = possibleDirs.get(random(0, possibleDirs.size()));
|
|
if (direction == Direction.GO_LEFT) {
|
|
col--;
|
|
grid.cells[row][col].exitType = EXIT_RIGHT;
|
|
} else if (direction == Direction.GO_UP) {
|
|
row--;
|
|
grid.cells[row][col].exitType = EXIT_DOWN;
|
|
} else if (direction == Direction.GO_RIGHT) {
|
|
grid.cells[row][col].exitType = grid.cells[row][col].exitType + EXIT_RIGHT;
|
|
col++;
|
|
} else if (direction == Direction.GO_DOWN) {
|
|
grid.cells[row][col].exitType = grid.cells[row][col].exitType + EXIT_DOWN;
|
|
row++;
|
|
}
|
|
grid.cells[row][col].count = count;
|
|
count++;
|
|
} else {
|
|
do {
|
|
if (col != grid.lastCol) {
|
|
col++;
|
|
} else if (row != grid.lastRow) {
|
|
row++;
|
|
col = 0;
|
|
} else {
|
|
row = 0;
|
|
col = 0;
|
|
}
|
|
} while (grid.cells[row][col].count == 0);
|
|
}
|
|
}
|
|
|
|
col = random(0, width - 1);
|
|
row = length - 1;
|
|
grid.cells[row][col].exitType += 1;
|
|
|
|
// top line
|
|
for (int i=0; i < width; i++) {
|
|
if (i == enterCol) {
|
|
out.print(". ");
|
|
} else {
|
|
out.print(".--");
|
|
}
|
|
}
|
|
out.println('.');
|
|
|
|
for (int i=0; i < length; i++) {
|
|
out.print("I");
|
|
for (int j = 0; j < width; j++) {
|
|
if (grid.cells[i][j].exitType == EXIT_UNSET || grid.cells[i][j].exitType == EXIT_DOWN) {
|
|
out.print(" I");
|
|
} else {
|
|
out.print(" ");
|
|
}
|
|
}
|
|
out.println();
|
|
for (int j = 0; j < width; j++) {
|
|
if (grid.cells[i][j].exitType == EXIT_UNSET || grid.cells[i][j].exitType == EXIT_RIGHT) {
|
|
out.print(":--");
|
|
} else {
|
|
out.print(": ");
|
|
}
|
|
}
|
|
out.println(".");
|
|
}
|
|
}
|
|
|
|
private ArrayList<Direction> getPossibleDirs(Grid grid, Cell cell) {
|
|
ArrayList<Direction> possibleDirs = new ArrayList<>(Arrays.asList(Direction.values()));
|
|
|
|
if (cell.col == FIRST_COL || grid.isPrevColSet(cell)) {
|
|
possibleDirs.remove(Direction.GO_LEFT);
|
|
}
|
|
if (cell.row == FIRST_ROW || grid.isPrevRowSet(cell)) {
|
|
possibleDirs.remove(Direction.GO_UP);
|
|
}
|
|
if (cell.col == grid.lastCol || grid.isNextColSet(cell)) {
|
|
possibleDirs.remove(Direction.GO_RIGHT);
|
|
}
|
|
if (cell.row == grid.lastRow || grid.isNextRowSet(cell)) {
|
|
possibleDirs.remove(Direction.GO_DOWN);
|
|
}
|
|
return possibleDirs;
|
|
}
|
|
|
|
private String displayTextAndGetInput(String text) {
|
|
out.print(text);
|
|
return kbScanner.next();
|
|
}
|
|
|
|
private static int getDelimitedValue(String text, int pos) {
|
|
String[] tokens = text.split(",");
|
|
try {
|
|
return Integer.parseInt(tokens[pos]);
|
|
} catch (Exception ex) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
private static String tab(int spaces) {
|
|
char[] spacesTemp = new char[spaces];
|
|
Arrays.fill(spacesTemp, ' ');
|
|
return new String(spacesTemp);
|
|
}
|
|
|
|
public static boolean random() {
|
|
Random random = new Random();
|
|
return random.nextBoolean();
|
|
}
|
|
|
|
public static int random(int min, int max) {
|
|
Random random = new Random();
|
|
return random.nextInt(max - min) + min;
|
|
}
|
|
|
|
public static class Cell {
|
|
int exitType = EXIT_UNSET;
|
|
int count = 0;
|
|
|
|
int col;
|
|
int row;
|
|
|
|
public Cell(int row, int col) {
|
|
this.row = row;
|
|
this.col = col;
|
|
}
|
|
|
|
@Override
|
|
public String toString() {
|
|
return "Cell{" +
|
|
"exitType=" + exitType +
|
|
", count=" + count +
|
|
", col=" + col +
|
|
", row=" + row +
|
|
'}';
|
|
}
|
|
}
|
|
|
|
public static class Grid {
|
|
Cell[][] cells;
|
|
|
|
int lastCol;
|
|
int lastRow;
|
|
|
|
int width;
|
|
|
|
public Grid(int length, int width) {
|
|
this.lastCol = width - 1;
|
|
this.lastRow = length - 1;
|
|
this.width = width;
|
|
|
|
this.cells = new Cell[length][width];
|
|
for (int i=0; i < length; i++) {
|
|
this.cells[i] = new Cell[width];
|
|
for (int j = 0; j < width; j++) {
|
|
this.cells[i][j] = new Cell(i, j);
|
|
}
|
|
}
|
|
}
|
|
|
|
public int setup() {
|
|
int enterCol = random(0, this.width);
|
|
cells[0][enterCol].count = 1;
|
|
return enterCol;
|
|
}
|
|
|
|
public boolean isPrevColSet(Cell cell) {
|
|
return 0 != cells[cell.row][cell.col - 1].count;
|
|
}
|
|
|
|
public boolean isPrevRowSet(Cell cell) {
|
|
return 0 != cells[cell.row - 1][cell.col].count;
|
|
}
|
|
|
|
public boolean isNextColSet(Cell cell) {
|
|
return 0 != cells[cell.row][cell.col + 1].count;
|
|
}
|
|
|
|
public boolean isNextRowSet(Cell cell) {
|
|
return 0 != cells[cell.row + 1][cell.col].count;
|
|
}
|
|
|
|
public Cell getPrevCol(Cell cell) { return cells[cell.row][--cell.col]; }
|
|
public Cell getPrevRow(Cell cell) { return cells[--cell.row][cell.col]; }
|
|
public Cell getNextCol(Cell cell) { return cells[cell.row][++cell.col]; }
|
|
public Cell getNextRow(Cell cell) { return cells[++cell.row][cell.col]; }
|
|
|
|
public Cell get(int row, int col) { return cells[row][col]; }
|
|
|
|
public Cell getFirstUnset(Cell cell) {
|
|
int col = cell.col;
|
|
int row = cell.row;
|
|
Cell newCell;
|
|
do {
|
|
if (col != this.lastCol) {
|
|
col++;
|
|
} else if (row != this.lastRow) {
|
|
row++;
|
|
col = 0;
|
|
} else {
|
|
row = 0;
|
|
col = 0;
|
|
}
|
|
} while ((newCell = cells[row][col]).count == 0);
|
|
return newCell;
|
|
}
|
|
}
|
|
}
|
|
|