我正在尝试弄清楚一个生成给定字符串所有排列的代码(来自《破解面试官》一书)的复杂度为O(n!)。
我知道这是最佳可能的复杂度,因为我们有n!个排列,但我想理解代码方式,因为并非每个执行此操作的算法都是O(n!)。
代码:
import java.util.*;
public class QuestionA {
public static ArrayList<String> getPerms(String str) {
if (str == null) {
return null;
}
ArrayList<String> permutations = new ArrayList<String>();
if (str.length() == 0) { // base case
permutations.add("");
return permutations;
}
char first = str.charAt(0); // get the first character
String remainder = str.substring(1); // remove the first character
ArrayList<String> words = getPerms(remainder);
for (String word : words) {
for (int j = 0; j <= word.length(); j++) {
String s = insertCharAt(word, first, j);
permutations.add(s);
}
}
return permutations;
}
public static String insertCharAt(String word, char c, int i) {
String start = word.substring(0, i);
String end = word.substring(i);
return start + c + end;
}
public static void main(String[] args) {
ArrayList<String> list = getPerms("abcde");
System.out.println("There are " + list.size() + " permutations.");
for (String s : list) {
System.out.println(s);
}
}
}
这是我至今为止的想法: 在任何函数调用中,可用的单词数量为(n-1);假设我们在余数长度为(n-1)的位置。现在要为这(n-1)个单词中的所有可能位置插入第n个元素,需要花费(n-1)*(n-1)的时间。
因此在执行过程中,总计需要进行(n-1)^2+(n-2)^2+(n-3)^2+....2^2+1^2次操作,我认为这不是n!。
我错在哪里了?