这段JavaScript的排列组合算法如何理解?
高洛峰
高洛峰 2016-11-07 15:50:30
0
1
529
//组合function C(arr, num){    var r=[];
    (function f(t,a,n){        if (n==0) return r.push(t);        for (var i=0,l=a.length; i<=l-n; i++){
            f(t.concat(a[i]), a.slice(i+1), n-1);
        }
    })([],arr,num);    return r;
}//排列function A(arr, num){    var r=[];
    (function f(t,a,n){        if (n==0) return r.push(t);        for (var i=0,l=a.length; i<l; i++){
            f(t.concat(a[i]), a.slice(0,i).concat(a.slice(i+1)), n-1);
        }
    })([],arr,num);    return r;
}

看了很久,越看越头晕,尤其是内部的循环和递归调用

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

répondre à tous(1)
三叔

通过操作,将arr的num种排列或组合存储到r中。每次递归,都是将当前的数组进行排列或者组合后又再次作为参数传入,这样每次重新生成的数组t都不一样。n作为num的计数器,在降到0以后,本次要求的种数就完成了,并且每次都把t推入了r数组。得到的r,就是不同的排列组合集合。

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal