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:
Base64 encoding và decoding trong Java 8
Guide to Guava Table
Java Program to Check if a Given Binary Tree is an AVL Tree or Not
Java Stream Filter with Lambda Expression
Java Program to Solve Tower of Hanoi Problem using Stacks
Java Program to Implement Pagoda
Java Program to Implement Circular Doubly Linked List
Using JWT with Spring Security OAuth
So sánh ArrayList và Vector trong Java
Tính đóng gói (Encapsulation) trong java
How to Get the Last Element of a Stream in Java?
Extract links from an HTML page
Java equals() and hashCode() Contracts
Java Program to Implement LinkedBlockingQueue API
Class Loaders in Java
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java
Quản lý bộ nhớ trong Java với Heap Space vs Stack
Registration – Password Strength and Rules
Java Program to Implement Leftist Heap
Check if there is mail waiting
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Java – Reader to InputStream
Java Program to Create the Prufer Code for a Tree
Jackson Ignore Properties on Marshalling
Get and Post Lists of Objects with RestTemplate
Introduction to Spring Data JDBC
Spring Boot - CORS Support
Java Program to Implement Graham Scan Algorithm to Find the Convex Hull
Java 8 Predicate Chain
Overflow and Underflow in Java
Introduction to the Java ArrayDeque
Sorting in Java