Java Program to Check if any Graph is Possible to be Constructed for a Given Degree Sequence

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:

Jackson Exceptions – Problems and Solutions
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
Java Program to Implement Direct Addressing Tables
Java Program to Implement RoleList API
Java Program to Implement PriorityQueue API
Spring Boot - Sending Email
Java Program to Implement TreeMap API
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Java Program to Implement Graph Structured Stack
Spring Boot Integration Testing with Embedded MongoDB
Database Migrations with Flyway
Java String Conversions
A Guide to the finalize Method in Java
The DAO with JPA and Spring
Java Program to Implement Iterative Deepening
Hướng dẫn sử dụng Printing Service trong Java
Spring Boot - Google OAuth2 Sign-In
Getting the Size of an Iterable in Java
Form Validation with AngularJS and Spring MVC
JPA/Hibernate Persistence Context
Java Program to Give an Implementation of the Traditional Chinese Postman Problem
Java Program to Find Shortest Path Between All Vertices Using Floyd-Warshall’s Algorithm
Chuyển đổi giữa các kiểu dữ liệu trong Java
REST Pagination in Spring
Create a Custom Auto-Configuration with Spring Boot
Java Program to Perform String Matching Using String Library
Java Program to find the number of occurrences of a given number using Binary Search approach
Java Program to Implement the Monoalphabetic Cypher
Java Program to Implement CountMinSketch
Java Program to Perform Preorder Non-Recursive Traversal of a Given Binary Tree
Java Program to Implement Hash Trie
The Order of Tests in JUnit