This is a java program to represent graph as a linked 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 Linked 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 linked 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_Linked_List
{
private Map<Integer, List<Integer>> adjacencyList;
public Represent_Graph_Linked_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_Linked_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_Linked_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 Linked 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_Linked_List.java $ java Represent_Graph_Linked_List Enter the number of vertices: 5 Enter the number of edges: 4 Enter the edges in the graph : <to> <from> 1 2 1 3 3 5 4 3 The Linked List Representation of the graph is: 1 -> 2 -> 3 2 -> 1 3 -> 1 -> 5 -> 4 4 -> 3 5 -> 3
Related posts:
Java Program to Implement String Matching Using Vectors
Serialization và Deserialization trong java
Java Program to Perform Finite State Automaton based Search
Spring Security Registration – Resend Verification Email
Retrieve User Information in Spring Security
Java Program to Sort an Array of 10 Elements Using Heap Sort Algorithm
New Features in Java 10
Java Program to Implement Sieve Of Sundaram
Spring Boot - Flyway Database
Java Program to Implement Hash Tables Chaining with Doubly Linked Lists
Tìm hiểu cơ chế Lazy Evaluation của Stream trong Java 8
Spring AMQP in Reactive Applications
Java Program to Represent Graph Using Incidence List
Serve Static Resources with Spring
Java Program to Permute All Letters of an Input String
Filtering and Transforming Collections in Guava
Java – Delete a File
Java Program to Implement Quick Hull Algorithm to Find Convex Hull
Loại bỏ các phần tử trùng trong một ArrayList như thế nào?
Java Program to Find Maximum Element in an Array using Binary Search
Java Program to Delete a Particular Node in a Tree Without Using Recursion
Java Program to Remove the Edges in a Given Cyclic Graph such that its Linear Extension can be Found
Java Program to find the peak element of an array using Binary Search approach
Error Handling for REST with Spring
How to Convert List to Map in Java
Spring 5 and Servlet 4 – The PushBuilder
Java Program to Implement Sorted Vector
Java Program to Check if a Given Binary Tree is an AVL Tree or Not
Java Program to Perform String Matching Using String Library
Introduction to Spring Data JDBC
Spring Boot - Enabling Swagger2
Java Program to Implement Depth-limited Search