【回溯+剪枝】字符串的排列


求解代码

java 复制代码
ArrayList<String> ans = new ArrayList<>();
    public ArrayList<String> Permutation(String str) {

        StringBuilder sb = new StringBuilder();
        boolean[] used = new boolean[str.length()];
        char[] chs = str.toCharArray();
        Arrays.sort(chs);
        str = new String(chs);
        backtrack(str, sb, used);
        return ans;
    }

    private void backtrack(String str, StringBuilder sb, boolean[] used) {
        if (sb.length() == str.length()) {
            ans.add(new String(sb));
            return;
        }

        for (int i = 0; i < str.length(); i++) {
            if (used[i]) {
                continue;
            }
            if (i > 0 && str.charAt(i) == str.charAt(i - 1) && !used[i - 1]) {
                continue;
            }
            sb.append(str.charAt(i));
            used[i] = true;
            backtrack(str, sb, used);
            sb.deleteCharAt(sb.length() - 1);
            used[i] = false;

        }
    }

小贴士

这道题本质上跟【回溯】有重复项数字的全排列是一样的,都是【有重复项数字的全排列问题】,只不过从普通的数组环境迁移到了字符串环境,其实字符串本质上也是数组,字符数组嘛。

相关推荐
Dlrb12111 天前
C语言-指针三
c语言·算法·指针·const·命令行参数
Tisfy1 天前
LeetCode 2540.最小公共值:双指针(O(m+n))
算法·leetcode·题解·双指针
IronMurphy1 天前
【算法四十七】152. 乘积最大子数组
算法
淘矿人1 天前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar1 天前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
落羽的落羽1 天前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈1 天前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
Godspeed Zhao1 天前
从零开始学AI16——SVM
算法·机器学习·支持向量机
江屿风1 天前
C++OJ题经验总结(竞赛)1
开发语言·c++·笔记·算法