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


求解代码

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;

        }
    }

小贴士

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

相关推荐
wuweijianlove15 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊16 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
AI手记叨叨16 小时前
机器学习可解释性工具SHAP
机器学习·shap
高洁0117 小时前
大模型部署资源不足?轻量化部署解决方案
python·深度学习·机器学习·数据挖掘·transformer
code_pgf17 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃17 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划
折哥的程序人生 · 物流技术专研17 小时前
从“卡死”到“秒过”:WMS销售数据跨库回填的极限优化之旅
数据库·机器学习·oracle
脱氧核糖核酸__17 小时前
LeetCode热题100——234.回文链表(两种解法)
c++·算法·leetcode·链表
IronMurphy17 小时前
【算法四十二】118. 杨辉三角 198. 打家劫舍
算法
电科一班林耿超17 小时前
第 16 课:动态规划专题(二)—— 子序列与子数组问题:面试最高频的 DP 题型
数据结构·算法·动态规划