从n个数中选择任意个数组成的组合

开发中遇到一个从n个数字中选择m(m



var aadd = [1, 2, 3, 4, 5, 6];
/**
 * 
 * @param aadd  所有的数字的数组
 * @param xuanlen  需要选择几个数
 * @returns {Array}返回一个数组
 */
function jisuan(aadd, xuanlen) { 
   var resultArr=[];
    deepCompute(aadd, xuanlen - 1, 0,"",resultArr);
    console.log(resultArr);
    function deepCompute(arr, choselen, index,str) {
        for (var a = index; a < arr.length - choselen; a++) {
            if (choselen != 0) {
                deepCompute(arr, choselen - 1, a + 1,str+arr[a]+",")
            } else {
                resultArr.push(str+arr[a])
            }
        }
    }
   
    return resultArr;
}
jisuan(aadd, 2);

你可能感兴趣的:(js,算法)