字符串全排列
输入一个长度为 n 字符串,打印出该字符串中字符的所有排列,你可以以任意顺序返回这个字符串数组。
例如输入字符串ABC,则输出由字符A,B,C所能排列出来的所有字符串ABC,ACB,BAC,BCA,CBA和CAB。
public class 字符串全排列 {
static List<String> result = new ArrayList<>();
static StringBuilder sb = new StringBuilder();
public static void main(String[] args) {
String str = "aab";
recursive(str.toCharArray(), new boolean[str.length()]);
System.out.println(result);
}
/**
* 递归回溯
*
* @param chars 字符数组
* @param used 元素是否被使用
*/
private static void recursive(char[] chars, boolean[] used) {
// 递归结束条件:完成1次完整排列
if (chars.length == sb.length()) {
result.add(sb.toString());
return;
}
for (int i = 0; i < chars.length; i++) {
// 这两行代码是去重,在树层上去重效率更高;如果是不重复字符串,则不需要这两行
if (i > 0 && chars[i] == chars[i - 1] && !used[i - 1]) {
continue;
}
if (used[i]) {
continue;
}
used[i] = true;
sb.append(chars[i]);
recursive(chars, used);
used[i] = false;
sb.deleteCharAt(sb.length() - 1);
}
}
}

浙公网安备 33010602011771号