/**    
 * 文件名:CombineAlgorithm.java    
 *    
 * 版本信息:    
 * 日期:2014-6-12    
 * Copyright Corporation 2014     
 * 版权所有    
 *    
 */


import java.util.Arrays;

/**
 * @Description:组合算法 从M个数中取出N个数,无顺序
 * 二维Object数组
 * @author :royoan
 * @since :2014-6-12 下午10:22:22
 * @version :0.0.1
 */
public class CombineAlgorithm {
    /* 原M个数据数组 */
    private Object[] src;

    /* src数组的长度 */
    private int m;

    /* 需要获取N个数 */
    private int n;
    
    //临时变量,obj的行数
    private int objLineIndex;
    
    /* 存放结果的二维数组 */
    public Object[][] obj;
    
    public CombineAlgorithm(Object[] src, int getNum) throws Exception {
        if (src == null)
            throw new Exception("原数组为空.");
        if (src.length < getNum)
            throw new Exception("要取的数据比原数组个数还 大 .");
        this.src = src;
        m = src.length;
        n = getNum;
        
        /*  初始化  */
        objLineIndex = 0;
        obj = new Object[combination(m,n)][n];
        
        Object[] tmp = new Object[n];
        combine(src, 0, 0, n, tmp);
    }

    /**
     * <p>
     * 计算 C(m,n)个数 = (m!)/(n!*(m-n)!)
     * </p>
     * 从M个数中选N个数,函数返回有多少种选法 参数 m 必须大于等于 n m = 0; n = 0; retuan 1;
     * 
     * @param m
     * @param n
     * @return
     * @since royoan 2014-6-13 下午8:25:33
     */
    public int combination(int m, int n) {
        if (m < n)
            return 0; // 如果总数小于取出的数,直接返回0

        int k = 1;
        int j = 1;
        // 该种算法约掉了分母的(m-n)!,这样分子相乘的个数就是有n个了
        for (int i = n; i >= 1; i--) {
            k = k * m;
            j = j * n;
            m--;
            n--;
        }
        return k / j;
    }
    
    /**
     * <p> 递归算法,把结果写到obj二维数组对象 </p>      
     * @param src
     * @param srcIndex
     * @param i
     * @param n
     * @param tmp
     * @since royoan 2014-6-15 上午11:22:24
     */
    private void combine(Object src[], int srcIndex, int i, int n, Object[] tmp) {
        int j;
        for (j = srcIndex; j < src.length - (n - 1); j++ ) {
            tmp[i] = src[j];
            if (n == 1) {
                //System.out.println(Arrays.toString(tmp));
                System.arraycopy(tmp, 0, obj[objLineIndex], 0, tmp.length);
                //obj[objLineIndex] = tmp;
                objLineIndex ++;
            } else {
                n--;
                i++;
                combine(src, j+1, i, n, tmp);
                n++;
                i--;
            }
        }
        
    }

    public Object[][] getResutl() {
        return obj;
    }
    
    /**
     * 用法实例    
     * @param args
     * @throws Exception
     * @since royoan 2014-6-15 下午8:21:05
     */
    public static void main(String[] args) throws Exception {
        Integer[] a = new Integer[]{1,2,3,4,5,6};
        CombineAlgorithm ca = new CombineAlgorithm(a, 3);
        
        Object[][] c = ca.getResutl();
        for (int i = 0; i < c.length; i++) {
            System.out.println(Arrays.toString(c[i]));
        }
    }

}
最近下载更多
微信网友_6705663532896256  LV1 2023年10月24日
piaierduo  LV1 2022年7月25日
cupshe-jhon  LV1 2022年3月9日
hongzh  LV1 2021年8月6日
BestSmile  LV1 2021年7月7日
gggyyyggg  LV1 2021年5月2日
可以  LV1 2021年3月27日
490166171  LV1 2021年2月2日
son1881  LV1 2020年11月30日
孙畅0024  LV1 2020年10月5日
最近浏览更多
1112WHQ  LV7 2023年11月3日
微信网友_6705663532896256  LV1 2023年10月24日
admess 2023年5月30日
暂无贡献等级
lironggang  LV38 2023年3月26日
heqian  LV16 2023年1月10日
piaierduo  LV1 2022年7月25日
myh7719  LV2 2022年6月13日
zjjhy2021 2022年3月26日
暂无贡献等级
rtt7319 2022年3月22日
暂无贡献等级
cupshe-jhon  LV1 2022年3月9日
顶部 客服 微信二维码 底部
>扫描二维码关注最代码为好友扫描二维码关注最代码为好友