以下是Java程序,用于打印字符串的所有排列-
public class Demo{ static void print_permutations(String my_str,String my_ans){ if (my_str.length() == 0){ System.out.print(my_ans + " "); return; } boolean my_arr[] = new boolean[26]; for (int i = 0; i < my_str.length(); i++){ char ch = my_str.charAt(i); String remaining_str = my_str.substring(0, i) + my_str.substring(i + 1); if (my_arr[ch - 'a'] == false) print_permutations(remaining_str, my_ans + ch); my_arr[ch - 'a'] = true; } } public static void main(String[] args){ String my_str = "hey"; System.out.println("字符串的排列是:"); print_permutations(my_str, ""); } }
输出结果
字符串的排列是: hey hye ehy eyh yhe yeh
名为Demo的类包含一个静态函数'print_permutations',该函数检查字符串是否为空,如果为空,则输出输出。现在,分配了一个名为“ my_arr”的布尔数组,其大小为36,其中默认情况下存储了“ false”值。每当使用字母时,其在数组中的索引都会更改为“ true”。
“ for”循环用于遍历字符串的长度,并检查字符串的ith个字符。字符串的其余部分(不带第ith个字符)将分配给名为“ remaining_str”的字符串。如果未使用该字符,则会对该函数进行递归调用。否则,不会发生任何函数调用。在main函数中,定义了一个字符串,并在该字符串上调用了该函数。