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:
Object Type Casting in Java
Merging Streams in Java
Examine the internal DNS cache
Java Program to Implement Cartesian Tree
Easy Ways to Write a Java InputStream to an OutputStream
Spring Security Custom AuthenticationFailureHandler
Java Program to Find Number of Articulation points in a Graph
Encode a String to UTF-8 in Java
Java 8 Predicate Chain
Remove the First Element from a List
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Creating Docker Images with Spring Boot
Java Program to Implement Heap’s Algorithm for Permutation of N Numbers
Java toString() Method
Spring Cloud AWS – Messaging Support
Spring Cloud Bus
Java Program to Find MST (Minimum Spanning Tree) using Prim’s Algorithm
Java Program to Find Number of Spanning Trees in a Complete Bipartite Graph
Programmatic Transaction Management in Spring
Hướng dẫn Java Design Pattern – Flyweight
Java Program to Check Whether a Directed Graph Contains a Eulerian Cycle
Explain about URL and HTTPS protocol
Introduction to Using FreeMarker in Spring MVC
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
Beans and Dependency Injection
Java Program to Compare Binary and Sequential Search
Chương trình Java đầu tiên
Java Program to Find Minimum Number of Edges to Cut to make the Graph Disconnected
Java Program to Implement JobStateReasons API
Java Program to Implement Interval Tree
Guide to the Java Clock Class
Java Program to Implement Bloom Filter