字符串全排列

输入一个长度为 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);
        }
    }
}
posted @ 2024-06-04 08:05  yfhu  阅读(59)  评论(0编辑  收藏  举报