diff options
author | Andinus <andinus@nand.sh> | 2021-11-02 14:21:07 +0530 |
---|---|---|
committer | Andinus <andinus@nand.sh> | 2021-11-02 14:21:49 +0530 |
commit | fad69ef7872e7fb25a0570adecf33f266439137a (patch) | |
tree | 2a8c1dde41fd888599a4f2087c55aa6685c55997 | |
parent | 31e11e8f2d1cdfbe1d06ad691cc22f582a45c282 (diff) | |
download | fornax-fad69ef7872e7fb25a0570adecf33f266439137a.tar.gz |
java/DFS: Make output parseable
-rw-r--r-- | algorithms/java/DFS.java | 44 |
1 files changed, 23 insertions, 21 deletions
diff --git a/algorithms/java/DFS.java b/algorithms/java/DFS.java index 5357a7d..671bfa8 100644 --- a/algorithms/java/DFS.java +++ b/algorithms/java/DFS.java @@ -12,6 +12,15 @@ public class CG_pathfinder { int curx; int cury; for (int i = 0; i < 4; i++) { + // Print the maze at every iteration. + for(int j = 0; j < maze.length; j++) + for(int k = 0; k < maze[j].length; k++) + if (visited[j][k]) + System.out.print("x"); + else + System.out.print(maze[j][k]); + System.out.print(" "); + curx = x; cury = y; @@ -23,13 +32,16 @@ public class CG_pathfinder { continue; //optional? //for square mazes if (maze[curx][cury] == '$') { - System.out.println("Path Found"); paths++; - for(int k = 0; k < maze.length; k++) { - for(int j = 0; j < maze.length; j++) - System.out.print(visited[k][j]); - System.out.println(); - } + System.out.print("|"); + // Print the maze at every iteration. + for(int j = 0; j < maze.length; j++) + for(int k = 0; k < maze[j].length; k++) + if (visited[j][k]) + System.out.print("x"); + else + System.out.print(maze[j][k]); + System.out.print(" "); } else if (maze[curx][cury] == 'x' || visited[curx][cury]) continue; else if (maze[curx][cury] == '_') { @@ -42,30 +54,20 @@ public class CG_pathfinder { public static void main(String[] args) { char[][] maze = { - {'*', '#', 'x'}, + {'*', '#', '_'}, {'_', '_', '_'}, {'_', '_', '$'} }; - int[] start = {0, 0}; - - System.out.println("Solving for the maze: "); - boolean[][] visited = new boolean[maze.length][maze.length]; - - for (int i = 0; i<maze.length; i++){ - for (int j = 0; j<maze[i].length; j++) - System.out.print(maze[i][j] + " "); // Printing maze - System.out.println(""); - } + int[] start = {0, 0}; + boolean[][] visited = new boolean[maze.length][maze[0].length]; for (int i = 0; i< maze.length; i++) for (int j = 0; j<maze.length; j++) visited[i][j] = false; + System.out.println(String.format("%d:%d", maze.length, maze[0].length)); visited[0][0] = true; traverse(start[0], start[1], maze, visited); - if (paths == 0) - System.out.println("no paths found"); - else - System.out.println(paths); + System.out.println(); } } |