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:
Jackson Ignore Properties on Marshalling
Quick Guide to @RestClientTest in Spring Boot
Java Program to Implement Maximum Length Chain of Pairs
Toán tử instanceof trong java
Spring Boot - Enabling Swagger2
A Guide to the Java ExecutorService
Read an Outlook MSG file
Java Program to Implement Sieve Of Atkin
Java Program to Find Basis and Dimension of a Matrix
Autoboxing và Unboxing trong Java
Chuyển đổi từ HashMap sang ArrayList
New Features in Java 13
A Guide to JUnit 5
Java Program to Implement WeakHashMap API
Using JWT with Spring Security OAuth (legacy stack)
Auditing with JPA, Hibernate, and Spring Data JPA
Spring Data Java 8 Support
Java Program to Implement Stack using Linked List
Call Methods at Runtime Using Java Reflection
Runnable vs. Callable in Java
Java Program to Compute Determinant of a Matrix
Rest Web service: Filter và Interceptor với Jersey 2.x (P1)
A Guide to LinkedHashMap in Java
Java Program to Perform Matrix Multiplication
Mapping Nested Values with Jackson
Java Program to Implement the Checksum Method for Small String Messages and Detect
Java Program to Perform Arithmetic Operations on Numbers of Size
MyBatis with Spring
Java Program to Perform Preorder Recursive Traversal of a Given Binary Tree
Query Entities by Dates and Times with Spring Data JPA
Java Program to Describe the Representation of Graph using Adjacency Matrix
Introduction to Spring Boot CLI