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:
A Guide to the ResourceBundle
Hướng dẫn Java Design Pattern – Object Pool
Automatic Property Expansion with Spring Boot
Spring Boot Tutorial – Bootstrap a Simple Application
Spring Security OAuth2 – Simple Token Revocation
REST Web service: Tạo ứng dụng Java RESTful Client với Jersey Client 2.x
Command-Line Arguments in Java
Spring Cloud AWS – RDS
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Java Program to Implement Expression Tree
How to Get a Name of a Method Being Executed?
Working with Tree Model Nodes in Jackson
Java Program to Perform Partition of an Integer in All Possible Ways
Convert Character Array to String in Java
Partition a List in Java
Comparing Dates in Java
Java Program to Implement Euclid GCD Algorithm
Programmatic Transaction Management in Spring
Spring Cloud AWS – Messaging Support
Converting Between a List and a Set in Java
Java Program to Find the GCD and LCM of two Numbers
Introduction to Java 8 Streams
Java – Write to File
Introduction to Spliterator in Java
Comparing Arrays in Java
Java Program to Implement Warshall Algorithm
Join and Split Arrays and Collections in Java
Java Program to Implement the Vigenere Cypher
Getting Started with GraphQL and Spring Boot
Jackson – Decide What Fields Get Serialized/Deserialized
Java Program to Solve a Matching Problem for a Given Specific Case
Iterating over Enum Values in Java