This Java program,to describe the representation of graph using incident list. Vertices and edges are stored as records or objects. Each vertex stores its incident edges, and each edge stores its incident vertices. This data structure allows the storage of additional data on vertices and edges.
Here is the source code of the Java program to describe the representation of graph using incident list. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Scanner;
public class IncidentList
{
private Map<Integer, List<Integer>> incidentList;
private int numberOfVertices;
public IncidentList(int numberOfVertices)
{
this.numberOfVertices = numberOfVertices;
incidentList = new HashMap<Integer, List<Integer>>();
for (int vertex = 1; vertex <= numberOfVertices; vertex++)
incidentList.put(vertex, new LinkedList<Integer>());
}
public void setEdge(int sourcevertex, int destinationvertex, int edgeNumber)
{
List<Integer> slist = incidentList.get(sourcevertex);
slist.add(edgeNumber);
return;
}
public List<Integer> getEdge(int vertex)
{
return incidentList.get(vertex);
}
public void printIncidentList()
{
System.out.println("Vertex EdgeNumber");
for (int vertex = 1; vertex <= numberOfVertices; vertex++)
{
System.out.print(vertex + ":");
List<Integer> edgeList = getEdge(vertex);
for (int j = 1; ; j++)
{
if (j != edgeList.size())
System.out.print(edgeList.get(j - 1) + "\t");
else
{
System.out.print(edgeList.get(j - 1));
break;
}
}
System.out.println();
}
}
public static void main(String... arg)
{
int numberOfVertices, numberOfEdges;
int source, destination, edgeNumber;
int edgeCount = 1;
Scanner scanner = new Scanner(System.in);
System.out.println("Enter the number of vertices");
numberOfVertices = scanner.nextInt();
IncidentList incidentList = new IncidentList(numberOfVertices);
System.out.println("Enter the number of edges");
numberOfEdges = scanner.nextInt();
System.out.println("Enter the edges format : <edgeNumber> <source> <destination>");
while (edgeCount <= numberOfEdges)
{
edgeNumber = scanner.nextInt();
source = scanner.nextInt();
destination = scanner.nextInt();
incidentList.setEdge(source, destination, edgeNumber);
edgeCount++;
}
System.out.println("\nThe Incident List is ");
incidentList.printIncidentList();
scanner.close();
}
}
$javac IterativeDeepening.java $java IterativeDeepening Enter the number of vertices 5 Enter the number of edges 5 Enter the edges format : <edgeNumber> <source> <destination> 1 1 2 2 2 4 3 5 4 4 4 3 5 5 1 The Incident List is Vertex EdgeNumber 1 : 1 5 2 : 1 2 3 : 4 4 : 2 3 4 5 : 3 5
Related posts:
Overview of Spring Boot Dev Tools
A Guide to Java SynchronousQueue
Prevent Cross-Site Scripting (XSS) in a Spring Application
Java Program to Optimize Wire Length in Electrical Circuit
Tips for dealing with HTTP-related problems
Java Program to Implement AttributeList API
Java Program to Implement Pollard Rho Algorithm
DynamoDB in a Spring Boot Application Using Spring Data
MyBatis with Spring
Posting with HttpClient
Guide to Mustache with Spring Boot
Mapping a Dynamic JSON Object with Jackson
Java program to Implement Tree Set
Introduction to Spring MVC HandlerInterceptor
Java Program to Perform Matrix Multiplication
Java Program to Implement Knight’s Tour Problem
Java Program to Perform the Shaker Sort
A Guide to Spring Boot Admin
Spring Security with Maven
Hướng dẫn Java Design Pattern – Intercepting Filter
Java Optional as Return Type
Java Deep Learning Essentials - Yusuke Sugomori
Spring Security – Reset Your Password
Ép kiểu trong Java (Type casting)
Reading an HTTP Response Body as a String in Java
Java Program to Give an Implementation of the Traditional Chinese Postman Problem
HttpClient 4 – Send Custom Cookie
Spring Cloud AWS – Messaging Support
Java Program to Implement Sieve Of Eratosthenes
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
XML Serialization and Deserialization with Jackson
Spring Boot with Multiple SQL Import Files