通常有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;
}