From 2e45d29d4519fff0615b719d99c52e787c3f4a34 Mon Sep 17 00:00:00 2001 From: vamsee Date: Fri, 19 Nov 2021 16:45:46 +0530 Subject: java/BFS: Find final path for solution --- algorithms/java/BFS.java | 94 +++++++++++++++++++++++++++++++++++------------- 1 file changed, 70 insertions(+), 24 deletions(-) diff --git a/algorithms/java/BFS.java b/algorithms/java/BFS.java index 477461c..a6f368a 100644 --- a/algorithms/java/BFS.java +++ b/algorithms/java/BFS.java @@ -1,14 +1,4 @@ -class Coordinates { - // for storing coordinates as object. - public int x, y; - - Coordinates(int x,int y) { - this.x = x; - this.y = y; - } -} - -public class BFS { +class BFS { // queue of coordinates. static Coordinates[] queue = new Coordinates[1000]; private static int front = -1; @@ -25,7 +15,7 @@ public class BFS { } static void dequeue() { - if (front == 0 && rear == 0) { + if (front == rear) { front = -1; rear = -1; } else { @@ -41,55 +31,111 @@ public class BFS { {-1, +0}, // up. }; - static void bfs(char[][] maze, Coordinates start, boolean[][] visited) { - int curx; - int cury; + static void bfs(char[][] maze, Coordinates start, boolean[][] visited,Coordinates [][] path) { for (int i = 0; i < 4; i++) { - curx = start.x; - cury = start.y; + int curx = start.x; + int cury = start.y; curx += dir[i][0]; cury += dir[i][1]; - + if (curx < 0 || cury < 0 || curx > maze.length - 1 || cury > maze.length - 1) { // for square... out of maze check. continue; - } else if (maze[curx][cury] == '$') { + } + // Print the maze on every iteration. + for(int j = 0; j < maze.length; j++) + for(int k = 0; k < maze[j].length; k++) { + if (maze[j][k] == '^' || maze[j][k] == '$') + System.out.print(maze[j][k]); + else { + if (j == curx && k == cury) + System.out.print("@"); + else { + if (visited[j][k]) + System.out.print("-"); + else + System.out.print(maze[j][k]); + } + } + } + System.out.println(); + if (maze[curx][cury] == '$') { + path[curx][cury]=new Coordinates(start.x,start.y); + System.out.println("Path found"); + + boolean[][] printpath=new boolean[maze.length][maze.length]; + for (int q = 0; q < maze.length; q++) { + for (int j = 0; j < maze.length; j++) { + printpath[q][j]=false; + } + } + printpath[0][0]=true; //start as true + while(curx != 0 || cury != 0){ + printpath[curx][cury] = true; + int temp = curx; + curx = path[curx][cury].x; + cury = path[temp][cury].y; + + //path stores parent of current coordinate + } + for(int d=0;d