JS从数组M中取出N个元素的所有组合

发布于 2022-09-12 13:22:12 字数 129 浏览 39 评论 0

数组 M = [1,2,3,4....]
从里面取N个项组合不重复
例如取两个为
1,2
1,3
1,4
2,3
2,4
3,4
取三个
1,2,3
1,2,4
2,3,4

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

初吻给了烟 2022-09-19 13:22:12

一个可用的实现(递归实现):

xrt=[];
function combine_increase( iArr , start, rt, count , NUM, arr_len){ // 从有arr_len个元素的数组中抽取NUM个元素的组合所有可能
    let i = 0;
    for(let i=start; i<arr_len+1-count; i++){
        rt[count - 1]=i;
        if( count -1 == 0){
            let tmp=[];
            for(let j=NUM-1;j>=0;j--){
                tmp.push(arr[rt[j]]);
            }
            xrt.push(tmp);
        }else{
            combine_increase( iArr , i+1 , rt, count -1 , NUM, arr_len);
        }
    }
}

let arr=[1,2,3,4,5,6,7,8,9,10];
var rt=new Array(4)
combine_increase(arr, 0, rt, 6, 6, 10);
console.log(xrt)

另外一个实现(非递归的):

const M_FILL = 0; // 填充模式
const M_INC = 1;  // 递增模式
function getArr(idx_arr,eArr,m){
    var rt=[];
    for(let i=0;i<m;i++){
        rt.push( eArr[idx_arr[i]])
    }
    return rt;
}

function IterativeCombos( n,  m,  idx_arr,  eArr ){// 从有n个元素的数组中抽取m个元素的的所有可能情况
    var rt=[];
    let mode=M_FILL;
    let i = 0;
    while( i>=0 ){
        if (mode == M_FILL) { 
            if(i==0){
                idx_arr[0]=0;
            }else{
                idx_arr[i]=idx_arr[i-1]+1;
            }
            if (i == m-1){
                rt.push( getArr(idx_arr,eArr,m));
                mode = M_INC;
            }else{
                i++;
            }
        }else{
            idx_arr[i]++;
            if( idx_arr[i]>n-m+i){
                i--;
            }else{
                if(i==m-1){
                    rt.push( getArr(idx_arr,eArr,m));
                }else{
                    i++;
                    mode=M_FILL;
                }
            }
        }
    }
    return rt;
}

console.log( IterativeCombos(10,4,idx_arr,arr )   )
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文