This is a java program to represent graph as a adjacency list. Each node will have a linked list consisting of node to which it is connected.
Here is the source code of the Java Program to Represent Graph Using Adjacency 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 adjacency list
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Scanner;
public class Represent_Graph_Adjacency_List
{
private Map<Integer, List<Integer>> adjacencyList;
public Represent_Graph_Adjacency_List(int v)
{
adjacencyList = new HashMap<Integer, List<Integer>>();
for (int i = 1; i <= v; i++)
adjacencyList.put(i, new LinkedList<Integer>());
}
public void setEdge(int to, int from)
{
if (to > adjacencyList.size() || from > adjacencyList.size())
System.out.println("The vertices does not exists");
List<Integer> sls = adjacencyList.get(to);
sls.add(from);
List<Integer> dls = adjacencyList.get(from);
dls.add(to);
}
public List<Integer> getEdge(int to)
{
if (to > adjacencyList.size())
{
System.out.println("The vertices does not exists");
return null;
}
return adjacencyList.get(to);
}
public static void main(String args[])
{
int v, e, count = 1, to, from;
Scanner sc = new Scanner(System.in);
Represent_Graph_Adjacency_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_Adjacency_List(v);
System.out.println("Enter the edges in the graph : <to> <from>");
while (count <= e)
{
to = sc.nextInt();
from = sc.nextInt();
glist.setEdge(to, from);
count++;
}
System.out
.println("The Adjacency List Representation of the graph is: ");
for (int i = 1; i <= v; i++)
{
System.out.print(i + "->");
List<Integer> edgeList = glist.getEdge(i);
for (int j = 1;; j++)
{
if (j != edgeList.size())
System.out.print(edgeList.get(j - 1) + " -> ");
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_Adjacency_List.java $ java Represent_Graph_Adjacency_List Enter the number of vertices: 4 5 Enter the number of edges: Enter the edges in the graph : <to> <from> 1 2 2 3 3 4 4 1 1 3 The Adjacency List Representation of the graph is: 1 -> 2 -> 4 -> 3 2 -> 1 -> 3 3 -> 2 -> 4 -> 1 4 -> 3 -> 1
Related posts:
A Guide to Spring Boot Admin
Spring 5 WebClient
Map Serialization and Deserialization with Jackson
Java Program to Implement Gabow Algorithm
How to Get a Name of a Method Being Executed?
Java Multi-line String
Entity To DTO Conversion for a Spring REST API
The Registration API becomes RESTful
Java Program to Implement Double Ended Queue
Zipping Collections in Java
Java Program to subtract two large numbers using Linked Lists
XML Serialization and Deserialization with Jackson
Java Program to Implement Selection Sort
Spring Cloud Connectors and Heroku
Spring Boot Security Auto-Configuration
A Guide to TreeSet in Java
Spring Boot Change Context Path
Create a Custom Exception in Java
Phương thức forEach() trong java 8
Hamcrest Collections Cookbook
Custom Thread Pools In Java 8 Parallel Streams
Java Program to Compute Discrete Fourier Transform Using Naive Approach
Java Program to Find the Longest Path in a DAG
The Difference Between Collection.stream().forEach() and Collection.forEach()
Use Liquibase to Safely Evolve Your Database Schema
How to Kill a Java Thread
Rate Limiting in Spring Cloud Netflix Zuul
Java 8 Stream findFirst() vs. findAny()
Java Program to Implement Queue using Two Stacks
A Guide to Iterator in Java
A Guide to the finalize Method in Java
Java Program to Implement ConcurrentSkipListMap API