一、题目描述
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串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;
}
}