我找到了以下Java代码。它计算字符串的所有排列。但是,我无法理解它在置换方法的for循环中的作用。更具体地说,我无法理解rem字符串和递归调用的目的。
对此有什么想法吗?
感谢。
void permutaion(String str){
permutaion(str,"");
}
void permutaion(String str, String prefix){
if(str.length() == 0){
System.out.println(prefix);
} else{
for(int i=0; i < str.length(); i++){
String rem = str.substring(0,i) + str.substring(i+1);
permutaion(rem, prefix + str.charAt(i));
}
}
}
答案 0 :(得分:0)
你应该在纸上手工运行这个代码,看看它的魔力并理解它:)
permutation
函数的递归用于置换输入字符串,而for循环用于所有可能的情况。 prefix
是递归完成时输入字符串的排列。
答案 1 :(得分:0)
基本思路是:获取给定 N 字符串的排列: