This is a java program to generate and print all the subsets of a given set as per lexicographical order, here we follow the numerical sequence. First generate all the subsets having only one element, then generate all the subsets having two elements and so on.
Here is the source code of the Java Program to Generate All Subsets of a Given Set in the Lexico-Graphic Order. 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 permutation of n elements in lexicographic order
import java.util.Random;
import java.util.Scanner;
public class Lexicographic_Permutation
{
public static int[] lexicographicOrder(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] + " ");
for (int i = 1; i < N; i++)
{
int j = i;
int temp = sequence[i];
while (j > 0 && temp < sequence[j - 1])
{
sequence[j] = sequence[j - 1];
j = j - 1;
}
sequence[j] = temp;
}
int[] mask = new int[(int) Math.pow(2, N)];
mask = lexicographicOrder(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 Lexicographic_Permutation.java
$ java Lexicographic_Permutation
Enter the number of elements in the set:
5
The elements in the set :
19 3 37 7 22
The permutations are:
{ }
{ 3 }
{ 7 }
{ 19 }
{ 22 }
{ 37 }
{ 3 7 }
{ 3 19 }
{ 7 19 }
{ 3 22 }
{ 7 22 }
{ 19 22 }
{ 3 37 }
{ 7 37 }
{ 19 37 }
{ 22 37 }
{ 3 7 19 }
{ 3 7 22 }
{ 3 19 22 }
{ 7 19 22 }
{ 3 7 37 }
{ 3 19 37 }
{ 7 19 37 }
{ 3 22 37 }
{ 7 22 37 }
{ 19 22 37 }
{ 3 7 22 37 }
{ 3 19 22 37 }
{ 7 19 22 37 }
{ 3 7 19 37 }
{ 3 7 19 22 }
{ 3 7 19 22 37 }
Related posts:
Guide to Java OutputStream
Hướng dẫn sử dụng luồng vào ra ký tự trong Java
Java Program to Implement Triply Linked List
Chuyển đổi giữa các kiểu dữ liệu trong Java
Using the Map.Entry Java Class
A Guide to BitSet in Java
Spring Boot - Twilio
OAuth2 Remember Me with Refresh Token
Configure a Spring Boot Web Application
Vấn đề Nhà sản xuất (Producer) – Người tiêu dùng (Consumer) và đồng bộ hóa các luồng trong Java
Spring Security Basic Authentication
Hướng dẫn Java Design Pattern – State
Java Program to Describe the Representation of Graph using Adjacency Matrix
Java Program to Implement Heap Sort Using Library Functions
Java Program to Generate All Possible Combinations Out of a, b, c, d, e
How to Kill a Java Thread
Spring Boot - Build Systems
Java Program to Find the Mode in a Data Set
Java Program to Implement JobStateReasons API
Java Program to Find Strongly Connected Components in Graphs
Java Program to Solve a Matching Problem for a Given Specific Case
Copy a List to Another List in Java
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
Quản lý bộ nhớ trong Java với Heap Space vs Stack
Java Program to Implement LinkedHashMap API
Spring Boot - Logging
How to Get a Name of a Method Being Executed?
Adding a Newline Character to a String in Java
A Guide to HashSet in Java
Java Program to Implement Hash Tables Chaining with Doubly Linked Lists
HttpClient Connection Management
Sending Emails with Java