有A、B、B、C、D、E这六个数字,用java写一个main函数,打印出所有不同的排列,如:ABBCDE、ABCDBE等.

要求:"E"不能在第三位,"C"与"E"不能相连。

A,B,C,D,E不是数字吧

import java.util.ArrayList;
import java.util.List;

public class Permutation {

public static void main(String[] args) {
List<String> list = new ArrayList<String>();

list.add("A");
list.add("B");
list.add("C");
list.add("D");
list.add("E");

permutation(list, new ArrayList<String>());
}

private static void permutation(List<String> src, List<String> desc) {
if(src.size() == 1){
desc.add(src.get(0));

StringBuffer sb = new StringBuffer();
for(String str: desc){
sb.append(str);
}

if(!(sb.charAt(2) == 'E' || sb.indexOf("CE") != -1 || sb.indexOf("EC") != -1)){
System.out.println(sb.toString());
}

}

final int size = desc.size();

for(int i = 0; i < src.size(); i++){
desc.add(src.get(i));

List<String> newSrcList = new ArrayList<String>();
newSrcList.addAll(src);
newSrcList.remove(i);

permutation(newSrcList, desc);
desc = desc.subList(0, size);
}

}

}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-04-10
两个“B”是说有两个数字相同吗?
相似回答