This is a java program to generate and print all possible subsets using the method of Binary Counting method. The generations of subsets are done using binary numbers. Let there be 3 elements in the set, we generate binary equivalent of 2^3 = 8 numbers(0-7), where each bit in a number represents the presence/absence of element in the subset. The element is present if bit is 1, absent otherwise. 010 – only second element is present in the subset.
Here is the source code of the Java Program to Implement the Binary Counting Method to Generate Subsets of a Set. 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 generate all subsets of given set of numbers using binary counting method
import java.util.Random;
import java.util.Scanner;
public class Binary_Counting_Subsets
{
public static int[] binary(int N)
{
int[] binary = new int[(int) Math.pow(2, N)];
for (int i = 0; i < Math.pow(2, N); i++)
{
int b = 1;
binary[i] = 0;
int num = i;
while (num > 0)
{
binary[i] += (num % 2) * b;
num /= 2;
b = b * 10;
}
}
return binary;
}
public static void main(String args[])
{
Random random = new Random();
Scanner sc = new Scanner(System.in);
System.out.println("Enter the number of elements in the set: ");
int N = sc.nextInt();
int[] sequence = new int[N];
for (int i = 0; i < N; i++)
sequence[i] = Math.abs(random.nextInt(100));
System.out.println("The elements in the set : ");
for (int i = 0; i < N; i++)
System.out.print(sequence[i] + " ");
int[] mask = new int[(int) Math.pow(2, N)];
mask = binary(N);
System.out.println("\nThe permutations are: ");
for (int i = 0; i < Math.pow(2, N); i++)
{
System.out.print("{");
for (int j = 0; j < N; j++)
{
if (mask[i] % 10 == 1)
System.out.print(sequence[j] + " ");
mask[i] /= 10;
}
System.out.println("}");
}
sc.close();
}
}
Output:
$ javac Binary_Counting_Subsets.java
$ java Binary_Counting_Subsets
Enter the number of elements in the set:
5
The elements in the set :
78 35 5 10 15
The permutations are:
{ }
{ 78 }
{ 35 }
{ 78 35 }
{ 5 }
{ 78 5 }
{ 35 5 }
{ 78 35 5 }
{ 10 }
{ 78 10 }
{ 35 10 }
{ 78 35 10 }
{ 5 10 }
{ 78 5 10 }
{ 35 5 10 }
{ 78 35 5 10 }
{ 15 }
{ 78 15 }
{ 35 15 }
{ 78 35 15 }
{ 5 15 }
{ 78 5 15 }
{ 35 5 15 }
{ 78 35 5 15 }
{ 10 15 }
{ 78 10 15 }
{ 35 10 15 }
{ 78 35 10 15 }
{ 5 10 15 }
{ 78 5 10 15 }
{ 35 5 10 15 }
{ 78 35 5 10 15 }
Related posts:
Java Program to Find k Numbers Closest to Median of S, Where S is a Set of n Numbers
Guide to the Volatile Keyword in Java
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Java IO vs NIO
Inheritance with Jackson
Java Program to Implement Gabow Algorithm
Java Program to Implement Stack using Linked List
Comparing Objects in Java
Spring Boot - Flyway Database
Configure a RestTemplate with RestTemplateBuilder
How to Store Duplicate Keys in a Map in Java?
Java Program to Implement Gale Shapley Algorithm
Java Program to Implement Sorted Circularly Singly Linked List
HttpClient Connection Management
Spring Boot - Tomcat Deployment
Spring Cloud AWS – RDS
DynamoDB in a Spring Boot Application Using Spring Data
Spring Boot - Securing Web Applications
A Quick Guide to Using Keycloak with Spring Boot
Java Program to Use Boruvka’s Algorithm to Find the Minimum Spanning Tree
Java Program to Find Nearest Neighbor Using Linear Search
Performance Difference Between save() and saveAll() in Spring Data
Java Program to Find a Good Feedback Edge Set in a Graph
JUnit5 @RunWith
Converting between an Array and a List in Java
Java Program to Generate a Graph for a Given Fixed Degree Sequence
Apache Commons Collections Bag
Configure a Spring Boot Web Application
Spring Boot - Hystrix
Java Program to Find Hamiltonian Cycle in an UnWeighted Graph
How to use the Spring FactoryBean?
Java Program to Implement IdentityHashMap API