剑指Offer(27):字符串的排列

一、题目描述

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


二、解题思路

求字符串的全排列,可以看成两步:
1)固定第一个字符,递归取得首位后面的各种字符串组合;
2)再把第一个字符与后面每一个字符交换,获得新的字符串组合。

例如:固定第一个字符a,递归后面的字符串即bcd
字符:a丨b丨c丨d
在bcd中固定第一个字符b,递归后面的字符串cd
字符:a丨b丨c丨d
在cd中得到两个字符串cd,dc
将b与每一位交换得到bcd,cbd,dcb,bdc,dbc,cdb
而后将a与该些字符串的每一位进行换位


三、编程实现

import java.util.ArrayList;
import java.util.Collections;

public class Solution {
    public ArrayList<String> Permutation(String str) {
        ArrayList<String> list = new ArrayList<>();
        if (str != null && str.length() > 0) {
            permutationCore(str.toCharArray(), 0, list);
            Collections.sort(list);
        }
        return list;
    }

    private void permutationCore(char[] cs, int i, ArrayList<String> list) {
        if (i == cs.length - 1) {
            String val = String.valueOf(cs);
            if (!list.contains(val)) {
                list.add(val);
            }
        } else {
            for (int j = i; j < cs.length; j++) {
                // 字符换位
                swap(cs, i, j);
                // 递归选择换位字符
                permutationCore(cs, i + 1, list);
                // 将字符再换回到上一个状态
                swap(cs, i, j);
            }
        }
    }

    private void swap(char[] cs, int i, int j) {
        char temp = cs[i];
        cs[i] = cs[j];
        cs[j] = temp;
    }
}

猜你喜欢

转载自blog.csdn.net/Fan0628/article/details/88964911