不同這程序檢查inputArray的每一種組合並打印 -調用方法輸出從主叫
Checker.java -
package testpj;
import java.util.ArrayList;
public class Checker {
public static void main(String[] args) {
String[] subarrayA = {"A0","A1","A2"};
String[] subarrayB = {"B0","B1"};
String[] subarrayC = {"C0","C1","C2","C3"};
String[][] inputArray = {subarrayA, subarrayB, subarrayC};
ArrayList<String> output = new ArrayList<String>();
String output1 = permute(inputArray, 0, output);
System.out.println("the output1: "+output1);
}
public static String permute(String array[][], int index, ArrayList<String> output){
if(index == array.length){
System.out.println(output.toString());
}
else{
for(int i=0 ; i<array[index].length ; i++){
output.add(array[index][i]);
permute(array,index+1,output);
output.remove(output.size() - 1);
}
}
return output.toString();
}
}
OUTPUT:
[A0, B0, C0]
[A0, B0, C1]
[A0, B0, C2]
[A0, B0, C3]
[A0, B1, C0]
[A0, B1, C1]
[A0, B1, C2]
[A0, B1, C3]
[A1, B0, C0]
[A1, B0, C1]
[A1, B0, C2]
[A1, B0, C3]
[A1, B1, C0]
[A1, B1, C1]
[A1, B1, C2]
[A1, B1, C3]
[A2, B0, C0]
[A2, B0, C1]
[A2, B0, C2]
[A2, B0, C3]
[A2, B1, C0]
[A2, B1, C1]
[A2, B1, C2]
[A2, B1, C3]
the output1: []
爲什麼output1不包含元素?
。所以當然它最終會變成空的。 – forgivenson 2015-04-03 15:32:10
它的工作方式與您編碼的方式完全相同。 – 2015-04-03 15:41:33