This is a java program to generate a random graph by generating random number of edges. One important thing to note here is, that we need to decide minimum and maximum number of nodes such that all edges get accommodated. Minimum number of vertices is positive solution to n(n-1) = 2e, where e is number of edges and maximum number of vertices is e+1.
Here is the source code of the Java Program to Create a Random Graph Using Random Edge Generation. 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 generate a random graph using random edge generation import java.util.HashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; import java.util.Random; import java.util.Scanner; public class Random_Edges_Graph { private Map<Integer, List<Integer>> adjacencyList; public Random_Edges_Graph(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[]) { System.out.println("Enter the number of edges: "); Scanner sc = new Scanner(System.in); int e = sc.nextInt(); try { int minV = (int) Math.ceil((1 + Math.sqrt(1 + 8 * e)) / 2); int maxV = e + 1; Random random = new Random(); int v = Math.abs(random.nextInt(maxV - minV) + minV); System.out.println("Random graph has "+v+" vertices"); Random_Edges_Graph reg = new Random_Edges_Graph(v); int count = 1, to, from; while (count <= e) { to = Math.abs(random.nextInt(v + 1 - 1) + 1); from = Math.abs(random.nextInt(v + 1 - 1) + 1); reg.setEdge(to, from); count++; } System.out .println("THe Adjacency List Representation of the random graph is: "); for (int i = 1; i <= v; i++) { System.out.print(i + " -> "); List<Integer> edgeList = reg.getEdge(i); if (edgeList.size() == 0) System.out.print("null"); else { 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 Random_Edges_Graph.java $ java Random_Edges_Graph Enter the number of edges: 5 Random graph has 4 vertices THe Adjacency List Representation of the random graph is: 1 -> 4 -> 4 2 -> 3 -> 3 3 -> 2 -> 4 -> 2 4 -> 1 -> 1 -> 3
Related posts:
Guide to Spring 5 WebFlux
Java Program to Find the Longest Subsequence Common to All Sequences in a Set of Sequences
Java Program to Implement Quick Sort with Given Complexity Constraint
Java Multi-line String
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Spring Boot - Enabling Swagger2
Java Program to Generate a Random UnDirected Graph for a Given Number of Edges
Arrays.asList vs new ArrayList(Arrays.asList())
Collect a Java Stream to an Immutable Collection
Java Program to Perform Left Rotation on a Binary Search Tree
String Joiner trong Java 8
HttpClient Basic Authentication
Model, ModelMap, and ModelAndView in Spring MVC
Get and Post Lists of Objects with RestTemplate
How to Delay Code Execution in Java
ExecutorService – Waiting for Threads to Finish
Summing Numbers with Java Streams
Java Program to Implement Euler Circuit Problem
Java Program to Implement First Fit Decreasing for 1-D Objects and M Bins
Java Program to Implement Min Hash
Java Program to Check if it is a Sparse Matrix
JPA/Hibernate Persistence Context
Java InputStream to String
Java Program to Solve any Linear Equations
Setting Up Swagger 2 with a Spring REST API
Java Program to Implement the Bin Packing Algorithm
Spring Cloud AWS – EC2
Tính đa hình (Polymorphism) trong Java
Remove the First Element from a List
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Guide to Java Instrumentation
A Guide to Java SynchronousQueue