package mbbc.test.second;
import java.util.ArrayList;
import java.util.List;
/**
*
* 递归方法从m个元素中取出n个元素的算法 ------分析
*
* @author update_java
*
*/
public class Main_92{
public static void main(String[] args) {
test1();
}
/**
* 每次都创建一个ArrayList对象,所以比较占用内存。
* 每递归一次都需要,创建一个ArrayList对象,所以比较占用内存。
* total : 362880
* time:2800毫秒
* @param s
* @param iL
* @param m
*/
private static char[] is = new char[] { '1', '2', '3', '4', '5', '6', '7', '8', '9'};
private static int total;
private static int m = 9;
private void plzh(String s, List<Integer> iL, int m) {
if(m == 0) {
System.out.println(s);
total++;
return;
}
List<Integer> iL2;
for(int i = 0; i < is.length; i++) {
iL2 = new ArrayList<Integer>(iL);
if(!iL.contains(i)) {
String str = s + is[i];
iL2.add(i);
plzh(str, iL2, m-1);
}
}
}
public static void test1() {
long startTime = System.currentTimeMillis();
List<Integer> iL = new ArrayList<Integer>();
new Main_92().plzh("", iL, m);
System.out.println("total : " + total);
long endTime = System.currentTimeMillis();
int custTime= (int)(endTime-startTime);
System.out.println( custTime+"毫秒");
}
static int count = 0;
/**
* 平均运行时间为4800毫秒 ,每次都要还原List对象,所以比较占用时间
* 总个数:362880
* @param lis
* @param start
*/
public static void f(List<Integer> lis,int start){
if(start>=lis.size()){
System.out.println(lis);
count++;
return ;
}
for(int i=1;i<=9;i++){
if(!lis.contains(i)){
lis.set(start, i);
}else{
continue;
}
f(lis,start+1);
lis.set(start, -1);
}
}
public static void test2(){
long startTime = System.currentTimeMillis();
int n = 9;
List<Integer> lis = new ArrayList<Integer>();
for(int i=0;i<n;i++){
lis.add(-1);
}
f(lis,0);
System.out.println("总个数:"+count);
long endTime = System.currentTimeMillis();
int custTime= (int)(endTime-startTime);
System.out.println( custTime+"毫秒");
}
}