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:
A Guide to Java HashMap
What is a POJO Class?
Spring Cloud – Securing Services
Java Scanner hasNext() vs. hasNextLine()
Debug a HttpURLConnection problem
Command-Line Arguments in Java
4 tính chất của lập trình hướng đối tượng trong Java
New Stream Collectors in Java 9
Java Program to Implement Strassen Algorithm
Guide to Apache Commons CircularFifoQueue
Java Program to Solve the 0-1 Knapsack Problem
HttpClient with SSL
Python Set clear()
Quick Guide to Spring Bean Scopes
Java Program to Implement wheel Sieve to Generate Prime Numbers Between Given Range
Rest Web service: Filter và Interceptor với Jersey 2.x (P1)
Adding Parameters to HttpClient Requests
Spring Boot - Rest Controller Unit Test
Spring Security OAuth Login with WebFlux
Assertions in JUnit 4 and JUnit 5
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
Java Program to subtract two large numbers using Linked Lists
Java Program to Implement Sparse Array
Hướng dẫn Java Design Pattern – Dependency Injection
Hướng dẫn Java Design Pattern – Adapter
Check If Two Lists are Equal in Java
Java Program to Represent Graph Using 2D Arrays
Using JWT with Spring Security OAuth
Primitive Type Streams in Java 8
Guide to the Synchronized Keyword in Java
Java Program to Check Whether a Directed Graph Contains a Eulerian Cycle