Java Program to do a Breadth First Search/Traversal on a graph non-recursively

Problem Description

Given a graph in the form of an adjacency matrix and a source vertex, write a program to perform a breadth-first search of the graph. In breadth-first search traversal, nodes are traversed level by level.Problem Solution

The idea is to store the source vertex in the queue. Now, iterate through the queue until it is empty. For every vertex retrieved from the queue, check which of its neighbours are still not processed. Add those neighbours to the queue.Program/Source Code

Here is the source code of the Java Program to do a Breadth First Search/Traversal on a graph non-recursively. The program is successfully compiled and tested using IDE IntelliJ Idea in Windows 7. The program output is also shown below.

//Java Program to do a Breadth First Search/Traversal on a graph non-recursively
 
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.Queue;
 
public class BreadthFirstSearch {
    // Function to perform breadth first search
    static void breadthFirstSearch(int[][] matrix, int source){
        boolean[] visited = new boolean[matrix.length];
        visited[source-1] = true;
        Queue<Integer> queue = new LinkedList<>();
        queue.add(source);
        System.out.println("The breadth first order is");
        while(!queue.isEmpty()){
            System.out.println(queue.peek());
            int x = queue.poll();
            int i;
            for(i=0; i<matrix.length;i++){
                if(matrix[x-1][i] == 1 && visited[i] == false){
                    queue.add(i+1);
                    visited[i] = true;
                }
            }
        }
    }
    // Function to read user input
    public static void main(String[] args) {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int vertices;
        System.out.println("Enter the number of vertices in the graph");
        try{
            vertices = Integer.parseInt(br.readLine());
        }catch(IOException e){
            System.out.println("An error occurred");
            return;
        }
        int[][] matrix = new int[vertices][vertices];
        System.out.println("Enter the adjacency matrix");
        int i,j;
        for(i=0; i<vertices; i++){
            for(j=0; j<vertices; j++){
                try{
                    matrix[i][j] = Integer.parseInt(br.readLine());
                }catch (IOException e){
                    System.out.println("An error occurred");
                }
            }
        }
        int source;
        System.out.println("Enter the source vertex");
        try{
            source = Integer.parseInt(br.readLine());
        }catch(IOException e){
            System.out.println("An error occurred");
            return;
        }
        breadthFirstSearch(matrix,source);
    }
}

Program Explanation

1. In function breadthFirstSearch(), a boolean array is created and visited value of the source is set to true.
2. Then a queue is created and source vertex is added to it.
3. The loop while(!queue.isEmpty()) traverses until the queue is empty.
4. The nested loop for(i=0; i&ltmatrix.length; i++) traverses through all the neighbours of the currently polled vertex from the queue.
5. The condition if(matrix[x-1][i] == 1 && visited[i] == false) looks for all the neighbours of the currently polled vertex and adds the non-visited vertices to the queue.

Time Complexity: O(n2) where n is the number of elements in the array.

Runtime Test Cases

Case 1 (Simple Test Case):
 
Enter the number of vertices in the graph
4
Enter the adjacency matrix
1
1
1
0
1
0
0
0
1
1
1
0
0
0
0
1
Enter the source vertex
3
The breadth first order is
3
1
2
 
Case 2 (Simple Test Case - another example):
 
Enter the number of vertices in the graph
3
Enter the adjacency matrix
0
0
0
1
0
1
1
1
1
Enter the source vertex
2
The breadth first order is
2
1
3

Related posts:

Guide to Dynamic Tests in Junit 5
Hướng dẫn sử dụng Java String, StringBuffer và StringBuilder
Hướng dẫn Java Design Pattern – Singleton
Java Program to Sort an Array of 10 Elements Using Heap Sort Algorithm
Java Program to Generate All Subsets of a Given Set in the Gray Code Order
Removing all Nulls from a List in Java
Spring Boot - Application Properties
Receive email using IMAP
Hướng dẫn Java Design Pattern – DAO
Spring WebClient Requests with Parameters
Java Program to Represent Linear Equations in Matrix Form
Converting Java Date to OffsetDateTime
CharSequence vs. String in Java
Introduction to Spring Cloud CLI
Java Program to Implement Interpolation Search Algorithm
How to Get a Name of a Method Being Executed?
The DAO with JPA and Spring
JWT – Token-based Authentication trong Jersey 2.x
Transactions with Spring and JPA
Exploring the Spring 5 WebFlux URL Matching
Java Program to Implement a Binary Search Tree using Linked Lists
Java Program to Implement CopyOnWriteArraySet API
Java Program to Implement Bellman-Ford Algorithm
Jackson Exceptions – Problems and Solutions
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
Spring Boot - Rest Template
Convert String to int or Integer in Java
Giới thiệu Google Guice – Aspect Oriented Programming (AOP)
Java Program to Perform Matrix Multiplication
Default Password Encoder in Spring Security 5
Java Program to Implement the Schonhage-Strassen Algorithm for Multiplication of Two Numbers
Java Program to Implement Rope