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:
Phương thức forEach() trong java 8
Java Program to Implement Stack using Two Queues
Giới thiệu Java 8
Shuffling Collections In Java
Initialize a HashMap in Java
Array to String Conversions
Consuming RESTful Web Services
How to Set TLS Version in Apache HttpClient
Java Program to Implement Fermat Factorization Algorithm
Upload and Display Excel Files with Spring MVC
Java Program to Implement D-ary-Heap
Java Program to Construct an Expression Tree for an Infix Expression
Java Program to Implement the Bin Packing Algorithm
How to Define a Spring Boot Filter?
Java Program to Perform Complex Number Multiplication
Spring Security 5 for Reactive Applications
Java Program to Implement Selection Sort
Java Program to Implement AttributeList API
Intro to the Jackson ObjectMapper
Spring 5 Testing with @EnabledIf Annotation
Java Program to Implement AA Tree
Hamcrest Collections Cookbook
Giới thiệu Design Patterns
Spring Data Reactive Repositories with MongoDB
Spring Autowiring of Generic Types
Java Program to Implement Horner Algorithm
How to Read a Large File Efficiently with Java
Converting Between a List and a Set in Java
Java Program to Find Transpose of a Graph Matrix
Immutable Map Implementations in Java
Convert char to String in Java
Java equals() and hashCode() Contracts