This is a java program to find the number of ways to write a given number as sum of numbers less than the number itself. We start with the number, number minus one is the next partition and so on, till all one’s are the last partition where we stop.
Here is the source code of the Java Program to Find the Number of Ways to Write a Number as the Sum of Numbers Smaller than Itself. 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 find the number of ways to write a number as a sum of smaller than the number itself
import java.util.Scanner;
public class NumberOf_Unique_Partitions
{
public static void print(int[] p, int n, int count)
{
for (int i = 0; i < n; i++)
System.out.print(p[i] + " ");
System.out.println();
int j;
for (j = 0; j < n; j++)
{
if (p[j] == 1)
continue;
else
break;
}
if (j == n)
System.out
.println("The number of ways to write a number as a sum of number smaller than itself is :"
+ (count - 1));
}
public static void generateUniquePartition(int n)
{
int[] p = new int[n];
int k = 0, count = 0;
p[k] = n;
while (true)
{
count++;
print(p, k + 1, count);
int rem_value = 0;
while (k >= 0 && p[k] == 1)
{
rem_value += p[k];
k--;
}
if (k < 0)
return;
p[k]--;
rem_value++;
while (rem_value > p[k])
{
p[k + 1] = p[k];
rem_value -= p[k];
k++;
}
p[k + 1] = rem_value;
k++;
}
}
public static void main(String args[])
{
System.out.println("Unique Partitioning of a given number");
System.out.println("Enter the number:");
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
generateUniquePartition(n);
sc.close();
}
}
Output:
$ javac NumberOf_Unique_Partitions.java $ java NumberOf_Unique_Partitions Unique Partitioning of a given number Enter the number: 6 6 5 1 4 2 4 1 1 3 3 3 2 1 3 1 1 1 2 2 2 2 2 1 1 2 1 1 1 1 1 1 1 1 1 1 The number of ways to write as a sum of number smaller than itself is :10
Related posts:
Testing an OAuth Secured API with Spring MVC
Spring Boot - Runners
Documenting a Spring REST API Using OpenAPI 3.0
Java Program to Implement Solovay Strassen Primality Test Algorithm
Java Program to Implement Counting Sort
Sắp xếp trong Java 8
Java Program to Perform Postorder Non-Recursive Traversal of a Given Binary Tree
Java Program to Compute the Area of a Triangle Using Determinants
RegEx for matching Date Pattern in Java
Comparing Two HashMaps in Java
Creating a Web Application with Spring 5
Java Program to Solve any Linear Equation in One Variable
Java IO vs NIO
Java Program to Implement ConcurrentLinkedQueue API
Intersection of Two Lists in Java
Java Program to Implement Slicker Algorithm that avoids Triangulation to Find Area of a Polygon
Spring Security Logout
The Order of Tests in JUnit
Giới thiệu Aspect Oriented Programming (AOP)
Giới thiệu Swagger – Công cụ document cho RESTfull APIs
Java Program to Find Basis and Dimension of a Matrix
Spring Boot - Building RESTful Web Services
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect
Java Program to Implement Suffix Tree
Automatic Property Expansion with Spring Boot
Java Program to Compute the Volume of a Tetrahedron Using Determinants
Spring Cloud – Securing Services
Hướng dẫn sử dụng Java Annotation
Spring Cloud AWS – Messaging Support
Hướng dẫn Java Design Pattern – DAO
Java 9 Stream API Improvements
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm