字符串的排列(回溯)

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

例子:
在这里插入图片描述
总而言之,就是不带重复的排列组合。

代码1:(回溯):

import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;

class Solution {
    //用来放所有可能的排列
    private List<String> list = new LinkedList();

    //将String s 转换为char[],当作全局变量,方便调换值
    private char[] s_char;

    public String[] permutation(String s) {
        this.s_char = s.toCharArray();
        doPermutation(0);
        return list.toArray(new String[list.size()]);
    }

    private void doPermutation(int x){
        //如果到了最后一位,就终止当前递归,并添加值。
        if (x == s_char.length-1){
            list.add(String.valueOf(s_char));
            return;
        }
        //HashSet主要是防止重复的值,例如abbc,这两个b其中取一个就够了。
        HashSet<Character> set = new HashSet<>();
        for (int i = x; i < s_char.length; i++){
            //判断是否重复
            if (set.contains(s_char[i])) continue;
            set.add(s_char[i]);

            //先调换,再递归,再还原,老回溯算法了
            swap(i, x);
            doPermutation(x+1);
            swap(i, x);
        }
    }

    //调换值
    private void swap(int a, int b){
        char temp = s_char[a];
        s_char[a] = s_char[b];
        s_char[b] = temp;
    }
}

代码1解释:
回溯算法的经典思路就是改变现场,递归循环,还原现场。之前另外一道题就是树的回溯,题目是【找和为某值的树的所有路径节点】。
这个算法给出String 10个字符,返回结果90多万个排列,可怕。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>