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


求解代码

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;

        }
    }

小贴士

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

相关推荐
Smart-佀2 小时前
FPGA入门:CAN总线原理与Verilog代码详解
单片机·嵌入式硬件·物联网·算法·fpga开发
OJAC1112 小时前
当DeepSeek V4遇见近屿智能:一场AI进化的叙事正在展开
人工智能·深度学习·机器学习
漫随流水2 小时前
leetcode算法(513.找树左下角的值)
数据结构·算法·leetcode·二叉树
万行2 小时前
机器人系统SLAM讲解
开发语言·python·决策树·机器学习·机器人
Quintus五等升2 小时前
深度学习②|实现人数回归预测
人工智能·深度学习·学习·机器学习·回归
大模型最新论文速读3 小时前
ProFit: 屏蔽低概率 token,解决 SFT 过拟合问题
人工智能·深度学习·机器学习·语言模型·自然语言处理
囊中之锥.3 小时前
机器学习算法详解:DBSCAN 聚类原理、实现流程与优缺点分析
算法·机器学习·聚类
AlenTech3 小时前
152. 乘积最大子数组 - 力扣(LeetCode)
算法·leetcode·职场和发展
Piar1231sdafa3 小时前
基于yolo13-C3k2-RVB的洗手步骤识别与检测系统实现_1
人工智能·算法·目标跟踪