算法---LeetCode 剑指 Offer 38. 字符串的排列

1. 题目

原题链接

输入一个字符串,打印出该字符串中字符的所有排列。

你可以以任意顺序返回这个字符串数组,但里面不能有重复元素。

示例:
输入:s = “abc”
输出:[“abc”,“acb”,“bac”,“bca”,“cab”,“cba”]

限制:
1 <= s 的长度 <= 8
Related Topics 回溯算法
👍 274 👎 0

2. 题解

2.1 解法1: 回溯(递归)

递归函数要点:

  1. 使用下标第多少位来控制递归终止
  2. 每次选取一个值后, 将其依次交换, 相当于在该位置选取不同的值
  3. 使用 set 记录该位置的元素, 若有重复, 则剪枝舍去
    class Solution {
        List<String> ans;
        char[] ss;

        public String[] permutation(String s) {
            ss = s.toCharArray();
            ans = new ArrayList<>();
            dfs(0);
            return ans.toArray(new String[0]);
        }

        public void dfs(int x) {
            if (x == ss.length - 1) {
                ans.add(String.valueOf(ss));
                return;
            }
            Set<Character> set = new HashSet<>();
            for (int i = x; i < ss.length ; i++) {

                if (set.contains(ss[i])) {
                    continue;
                }
                set.add(ss[i]);
                swap(x, i);
                dfs(x + 1);
                swap(i, x);
            }

        }

        public void swap(int a, int b) {
            char temp = ss[a];
            ss[a] = ss[b];
            ss[b] = temp;
        }

    }

参考:
剑指 Offer 38. 字符串的排列(回溯法,清晰图解)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值