List all permutations of a given string in dictionary order in Java

Understanding String Permutations

String permutations refer to all possible arrangements of characters in a given string. The dictionary order means sorting them lexicographically.

We will explore three different methods to list all permutations of a given string in Java.

Method 1: Using Recursion

This method generates permutations recursively by swapping characters.

import java.util.*;

public class PermutationsRecursion {
    static void permute(String str, String answer) {
        if (str.length() == 0) {
            System.out.println(answer);
            return;
        }
        for (int i = 0; i < str.length(); i++) {
            char ch = str.charAt(i);
            String rest = str.substring(0, i) + str.substring(i + 1);
            permute(rest, answer + ch);
        }
    }
    public static void main(String[] args) {
        String str = "abc";
        permute(str, "");
    }
}
            
Input: abc
Output: abc, acb, bac, bca, cab, cba

Method 2: Using Next Permutation

This method generates permutations in lexicographical order.

import java.util.*;

public class NextPermutation {
    public static void main(String[] args) {
        String str = "abc";
        char[] arr = str.toCharArray();
        Arrays.sort(arr);
        do {
            System.out.println(new String(arr));
        } while (nextPermutation(arr));
    }
    private static boolean nextPermutation(char[] arr) {
        int i = arr.length - 2;
        while (i >= 0 && arr[i] >= arr[i + 1]) i--;
        if (i < 0) return false;
        int j = arr.length - 1;
        while (arr[j] <= arr[i]) j--;
        swap(arr, i, j);
        reverse(arr, i + 1, arr.length - 1);
        return true;
    }
    private static void swap(char[] arr, int i, int j) {
        char temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }
    private static void reverse(char[] arr, int i, int j) {
        while (i < j) swap(arr, i++, j--);
    }
}
            
Input: abc
Output: abc, acb, bac, bca, cab, cba

Method 3: Using Collections

This method sorts the string and uses Java's next permutation approach.

import java.util.*;

public class CollectionsPermutation {
    public static void main(String[] args) {
        String str = "abc";
        List permutations = new ArrayList<>();
        generatePermutations("", str, permutations);
        Collections.sort(permutations);
        for (String perm : permutations) {
            System.out.println(perm);
        }
    }
    private static void generatePermutations(String prefix, String str, List permutations) {
        if (str.isEmpty()) {
            permutations.add(prefix);
        } else {
            for (int i = 0; i < str.length(); i++) {
                generatePermutations(prefix + str.charAt(i), str.substring(0, i) + str.substring(i + 1), permutations);
            }
        }
    }
}
            
Input: abc
Output: abc, acb, bac, bca, cab, cba
Strings

Below You will find some of the most important codes in languages like C, C++, Java, and Python. These codes are of prime importance for college semester exams and online tests.

Getting Started

Check whether a character is a vowel or consonant: C C++ Java Python

Check whether a character is an alphabet or not: C C++ Java Python

Find the ASCII value of a character: C C++ Java Python

Length of the string without using strlen() function: C C++ Java Python

Toggle each character in a string: C C++ Java Python

Count the number of vowels: C C++ Java Python

Remove the vowels from a string: C C++ Java Python

Check if the given string is Palindrome or not: C C++ Java Python

Print the given string in reverse order: C C++ Java Python

Remove all characters from string except alphabets: C C++ Java Python

Remove spaces from a string: C C++ Java Python

Replace a sub-string in a string: C C++ Java Python

Count common sub-sequences in two strings: C C++ Java Python

Compare two strings with wildcard support in one of them: C C++ Java Python

List all permutations of a given string in dictionary order: C C++ Java Python

Operations on Strings: C C++ Java Python