Јава програм за израчунавање свих пермутација низа

У овом примеру научићемо да рачунамо све пермутације низа у Јави.

Да бисте разумели овај пример, требало би да имате знање о следећим темама програмирања Јава:

  • Јава Стринг
  • Јава Рецурсион
  • Класа Јава скенера

Пермутација низа значи све могуће нове низове који се могу формирати заменом положаја знакова низа. На пример, низ АБЦ има пермутације (АБЦ, АЦБ, БАЦ, БЦА, ЦАБ, ЦБА) .

Пример: Јава програм за добивање свих пермутација низа

 import java.util.HashSet; import java.util.Scanner; import java.util.Set; class Main ( public static Set getPermutation(String str) ( // create a set to avoid duplicate permutation Set permutations = new HashSet(); // check if string is null if (str == null) ( return null; ) else if (str.length() == 0) ( // terminating condition for recursion permutations.add(""); return permutations; ) // get the first character char first = str.charAt(0); // get the remaining substring String sub = str.substring(1); // make recursive call to getPermutation() Set words = getPermutation(sub); // access each element from words for (String strNew : words) ( for (int i = 0;i<=strNew.length();i++)( // insert the permutation to the set permutations.add(strNew.substring(0, i) + first + strNew.substring(i)); ) ) return permutations; ) public static void main(String() args) ( // create an object of scanner class Scanner input = new Scanner(System.in); // take input from users System.out.print("Enter the string: "); String data = input.nextLine(); System.out.println("Permutations of " + data + ": " + getPermutation(data)); ) )

Оутпут

 Унесите низ: АБЦ пермутације АБЦ: (АЦБ, БЦА, АБЦ, ЦБА, БАЦ, ЦАБ)

У Јави смо користили рекурзију за израчунавање свих пермутација низа. Овде чувамо пермутацију у скупу. Дакле, неће бити дуплираних пермутација.

Занимљиви Чланци...