This is a java program to check graph construction is possible or not using given degree sequence. If the sum of degree is even graph construction is possible, not otherwise.
Here is the source code of the Java Program to Check if any Graph is Possible to be Constructed for a Given Degree Sequence. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.sanfoundry.combinatorial;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class CheckGraphConstuction
{
public static Integer sum(List<Integer> list)
{
Integer sum = 0;
for (Integer integer : list)
{
sum += integer;
}
return sum;
}
public static void main(String[] args)
{
Scanner sc = new Scanner(System.in);
System.out.println("Enter the number of vertices: ");
Integer n = sc.nextInt();
System.out
.println("Enter the Degree Sequence: <Degree sequence is always in non-increasing order>");
List<Integer> sequence = new ArrayList<Integer>();
while (n > 0)
{
sequence.add(sc.nextInt());
n--;
}
System.out.println(sequence.toString());
if (sum(sequence) % 2 == 0)
{
System.out
.println("Graph can be constructed using the given sequence G=("
+ sequence.size()
+ ", "
+ (sum(sequence) / 2)
+ ").");
}
sc.close();
}
}
Output:
$ javac CheckGraphConstuction.java $ java CheckGraphConstuction Enter the number of vertices: 7 Enter the Degree Sequence: <Degree sequence is always in non-increasing order> 5 3 3 2 2 1 0 [5, 3, 3, 2, 2, 1, 0] Graph can be constructed using the given sequence G=(7, 8). Enter the number of vertices: 3 Enter the Degree Sequence: <Degree sequence is always in non-increasing order> 3 3 1 [3, 3, 1] no soultion exists.
Related posts:
Java Program to Implement DelayQueue API
Hướng dẫn Java Design Pattern – Chain of Responsibility
A Guide to JUnit 5 Extensions
Hướng dẫn Java Design Pattern – Singleton
Loại bỏ các phần tử trùng trong một ArrayList như thế nào?
Spring 5 Testing with @EnabledIf Annotation
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Hướng dẫn sử dụng Lớp FilePermission trong java
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java
Java Program to Compute Cross Product of Two Vectors
Java Program to Implement PriorityBlockingQueue API
Lớp TreeMap trong Java
Java Program to Implement Coppersmith Freivald’s Algorithm
Shuffling Collections In Java
Java Program to Generate All Possible Combinations of a Given List of Numbers
Date Time trong Java 8
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect
Hướng dẫn Java Design Pattern – MVC
Hướng dẫn sử dụng Java Annotation
Summing Numbers with Java Streams
Java Program to Implement String Matching Using Vectors
JUnit 5 @Test Annotation
Spring AMQP in Reactive Applications
Java Program to Implement First Fit Decreasing for 1-D Objects and M Bins
Comparing Strings in Java
How to Return 404 with Spring WebFlux
Dockerizing a Spring Boot Application
Spring @Primary Annotation
Java Program to Implement Gift Wrapping Algorithm in Two Dimensions
Spring REST with a Zuul Proxy
Giới thiệu Google Guice – Aspect Oriented Programming (AOP)
Java Program to Find Median of Elements where Elements are Stored in 2 Different Arrays