Java实现多数组排列组合

  • 使用递归实现的多数组排列组合,代码如下

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

public class ArrayCombination {

    public static List<Object[]> combination(List<Object[]> dataList, int index, List<Object[]> resultList){ 
        if(index==dataList.size()){
            return resultList;
        }
        
        List<Object[]> resultList0=new ArrayList<Object[]>();
        if(index==0){
            Object[] objArr=dataList.get(0);
            for(Object obj : objArr){
                resultList0.add(new Object[]{obj});
                
            }
        }else{
            Object[] objArr=dataList.get(index);
            for(Object[] objArr0: resultList){
                for(Object obj : objArr){
                    //复制数组并扩充新元素
                    Object[] objArrCopy=new Object[objArr0.length+1];
                    System.arraycopy(objArr0, 0, objArrCopy, 0, objArr0.length);
                    objArrCopy[objArrCopy.length-1]=obj;
                    
                    //追加到结果集
                    resultList0.add(objArrCopy);
                }
            }
        }
        return combination(dataList,++index,resultList0);
    }
    
    public static void main(String[] args) {
        Object[] arr1=new Object[]{"A1","A2","A3"};
        Object[] arr2=new Object[]{"B1","B2","B3","B4"};
        Object[] arr3=new Object[]{"C1","C2","C3","C4","C5"};
        
        List<Object[]> dataList=new ArrayList<Object[]>();
        dataList.add(arr1);
        dataList.add(arr2);
        dataList.add(arr3);
        List<Object[]> resultList= combination(dataList,0,null); 
        
        //打印组合结果 
        for(int i=0;i<resultList.size();i++){
            Object[] objArr=resultList.get(i);
            System.out.print("\n组合"+(i+1)+"---");
            for(Object obj : objArr){
                System.out.print( obj+" "); 
            }
        } 
        
        /** 
            输出结果:
             组合1---A1 B1 C1 
            组合2---A1 B1 C2 
            组合3---A1 B1 C3 
            组合4---A1 B1 C4 
            组合5---A1 B1 C5 
            组合6---A1 B2 C1 
            组合7---A1 B2 C2 
            。。。
            
         */
        
    }
}

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值