通过递归方式求排列

通常有N个数的话,其全排列情况是N!,但是如何枚举这些全排列呢?一种很直观的方法是使用递归的方式。

如果只有一个元素A,则全排列必然是A;

如果是有两个元素AB,我们可以先把第一个字母取出来,然后往剩下的字符串中插入,B只有前后两个位置,因此,可以构成AB和BA;

如果是三个元素ABC,我们可以先把A取出来,然后求BC的排列,这个问题已经在前面解决了,可以获得BC和CB两种排列,以BC为例,我们把A插入其中,那么能够插入的位置有三个,分别是B前面,BC中间和C后面,也就是插入结果为ABC、BAC和BCA,对于CB这种排列,操作是类似的。

因此,可以形成如下递归链:对于ABC...共计N个字母,可以先去A和剩余字符串BC...,然后求剩余部分N-1个元素的全排列,将会获得(N-1)!种排列,然后对于其中每一个排列,A都可以有N个位置插入,构成N*(N-1)!=N!个全排列,实现代码如下:

    //通过递归方式对求解字符串的全排列
    public static ArrayList<String> Permutations(String s)
    {
        ArrayList<String> ret = new ArrayList<>();
        //basic situation
        if (s.length() == 1)
        {
            ret.add(s);
            return ret;
        }
        char c = s.charAt(0);
        ArrayList<String> pre = Permutations(s.substring(1));
        for (int i = 0; i < pre.size(); i++)
        {
            String a = pre.get(i);
            for (int k = 0; k <= a.length(); k++)
            {
                StringBuilder sb = new StringBuilder(a);
                sb.insert(k, c);
                ret.add(sb.toString());
            }
        }
        return ret;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值