This is a java program to represent graph as a incidence list. The incidence matrix of G is a n × m matrix (b_{ij}), where n and m are the numbers of vertices and edges respectively, such that b_{ij} = 1 if the vertex v_i and edge x_j are incident and 0 otherwise. If this relationship is represented by a list, list is known as incidence list.
Here is the source code of the Java Program to Represent Graph Using Incidence List. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a java program to represent graph as a incidence list
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.LinkedList;
import java.util.Scanner;
public class Represent_Graph_Incidence_List
{
private Map<Integer, List<Integer>> incidenceList;
private int v;
public Represent_Graph_Incidence_List(int vertices)
{
v = vertices;
incidenceList = new HashMap<Integer, List<Integer>>();
for (int i = 1; i <= v; i++)
incidenceList.put(i, new LinkedList<Integer>());
}
public void setEdge(int to, int from, int edge_number)
{
List<Integer> slist = incidenceList.get(to);
slist.add(edge_number);
List<Integer> dlist = incidenceList.get(from);
dlist.add(edge_number);
}
public List<Integer> getEdge(int vertex)
{
return incidenceList.get(vertex);
}
public static void main(String args[])
{
int v, e, count = 1, to, from, edgeNumber;
Scanner sc = new Scanner(System.in);
Represent_Graph_Incidence_List glist;
try
{
System.out.println("Enter the number of vertices: ");
v = sc.nextInt();
System.out.println("Enter the number of edges: ");
e = sc.nextInt();
glist = new Represent_Graph_Incidence_List(v);
System.out
.println("Enter the edges in the graph : <edgenumber> <to> <from>");
while (count <= e)
{
edgeNumber = sc.nextInt();
to = sc.nextInt();
from = sc.nextInt();
glist.setEdge(to, from, edgeNumber);
count++;
}
System.out
.println("The Incidence List Representation of the graph is: ");
System.out.println("Vertex EdgeNumber");
for (int vertex = 1; vertex <= v; vertex++)
{
System.out.print(vertex + "\t:");
List<Integer> edgeList = glist.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();
}
}
catch (Exception E)
{
System.out.println("Something went wrong");
}
sc.close();
}
}
Output:
$ javac Represent_Graph_Incidence_List.java $ java Represent_Graph_Incidence_List Enter the number of vertices: 5 Enter the number of edges: 5 Enter the edges in the graph : <edgenumber> <to> <from> 1 1 2 2 2 4 3 5 4 4 4 3 5 5 1 The Incidence List Representation of the graph is: Vertex EdgeNumber 1 :1 5 2 :1 2 3 :4 4 :2 3 4 5 :3 5
Related posts:
Java Program to Solve Set Cover Problem assuming at max 2 Elements in a Subset
Debug a JavaMail Program
Java – Byte Array to Reader
Java Program to Find the Peak Element of an Array O(n) time (Naive Method)
A Guide to System.exit()
Java Deep Learning Essentials - Yusuke Sugomori
Java Program to Implement Hash Tables Chaining with List Heads
Convert a Map to an Array, List or Set in Java
Iterable to Stream in Java
Java Program to Implement Fermat Factorization Algorithm
Sending Emails with Java
The XOR Operator in Java
Java Program to Perform Searching Using Self-Organizing Lists
Documenting a Spring REST API Using OpenAPI 3.0
How to Define a Spring Boot Filter?
Java Program to Generate a Graph for a Given Fixed Degree Sequence
How to Use if/else Logic in Java 8 Streams
Java Program to Perform Cryptography Using Transposition Technique
Java – Reader to InputStream
Write/Read cookies using HTTP and Read a file from the internet
Deploy a Spring Boot App to Azure
Từ khóa static và final trong java
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
The DAO with Spring and Hibernate
Introduction to Spring Boot CLI
Spring REST API + OAuth2 + Angular (using the Spring Security OAuth legacy stack)
Jackson Annotation Examples
Java Program to Find Number of Articulation points in a Graph
Hướng dẫn Java Design Pattern – MVC
Java Program to Implement Min Hash
Java Program to subtract two large numbers using Linked Lists
Java Program to Implement Sieve Of Eratosthenes