字符串的排列(全排列)——Java、回溯法

本文介绍了使用Java和回溯法解决字符串全排列问题的方法。针对长度不超过9且包含重复字符的字母字符串,通过深度优先搜索策略,每次固定一个字符并递归处理剩余部分,最后在回溯过程中恢复原状态,完成所有可能的排列组合。

题目描述

输入一个字符串,按字典序打印出该字符串中字符的所有排列。
例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。

输入描述:

输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。

Solution:

从这张图中,我们可以看出来,找全排列类似于深度优先遍历,

深度优先最关键的就是要记住上一个状态,而所谓回溯就是要回到上一没有操作过的状态,再去考虑别的情况。

例如上面这个图,我们的想法是每次都把一个数固定在前面,

让后面的数递归地进行全排列,这样每个数都固定过以后就能找出所有排列。

关键的地方在于,我们把每个数固定在前面并让后面的进行全排列完毕以后,

要恢复原来的状态,也就需要交换回来。

具体的代码如下:

class Solution {
    public List<List<Integer>> permute(int[] nums) {
        List<List<Integer>> ret = new ArrayList<>();
        ArrayList<Integer> nums_lst = new ArrayList<Integer>();
        for (int num : nums)
          nums_lst.add(num);

        int n = nums.length;
        backtrack(n, nums_lst, ret, 0);
        return ret;

    }
    private void backtrack(int n, ArrayList<Integer> nums_lst,List<List<Integer>> ret, int first)
    {
        if(first == n)
        {
            ret.add(new ArrayList<>(nums_lst));
            return;
        }
        for(int i = first;i<n;i++)
        {
            Collections.swap(nums_lst,first,i);
            backtrack(n,nums_lst,ret,first+1);
            Collections.swap(nums_lst,first,i);
        }
    }
}

通过如上代码,我们就可以解决递归,回溯调用了

评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Strom72

如对你有帮助,可以请我喝杯咖啡

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值