高效的java版排列组合算法
本文实例为大家分享了java排列组合算法的具体代码,供大家参考,具体内容如下
packageBeanUtil;
importjava.util.ArrayList;
importjava.util.List;
importcom.work.core.exception.OurException;
/**
*统计任三出现的最多的几率的组合
*
*@authorwangmingjie
*@date2009-1-1下午01:22:19
*/
publicclassCopy_2_of_StatisAnyThree{
//组合算法
//本程序的思路是开一个数组,其下标表示1到m个数,数组元素的值为1表示其下标
//代表的数被选中,为0则没选中。
//首先初始化,将数组前n个元素置1,表示第一个组合为前n个数。
//然后从左到右扫描数组元素值的“10”组合,找到第一个“10”组合后将其变为
//“01”组合,同时将其左边的所有“1”全部移动到数组的最左端。
//当第一个“1”移动到数组的m-n的位置,即n个“1”全部移动到最右端时,就得
//到了最后一个组合。
//例如求5中选3的组合:
//11100//1,2,3
//11010//1,2,4
//10110//1,3,4
//01110//2,3,4
//11001//1,2,5
//10101//1,3,5
//01101//2,3,5
//10011//1,4,5
//01011//2,4,5
//00111//3,4,5
publicstaticvoidmain(String[]args){
Copy_2_of_StatisAnyThrees=newCopy_2_of_StatisAnyThree();
s.printAnyThree();
}
/**
*
*/
publicvoidprintAnyThree(){
int[]num=newint[]{1,2,3,4,5,6};
print(combine(num,3));
}
/**
*从n个数字中选择m个数字
*@parama
*@paramm
*@return
*/
publicListcombine(int[]a,intm){
intn=a.length;
if(m>n){
thrownewOurException("错误!数组a中只有"+n+"个元素。"+m+"大于"+2+"!!!");
}
Listresult=newArrayList();
int[]bs=newint[n];
for(inti=0;i
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。