这段JavaScript的排列组合算法如何理解??
//组合 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; }
看了很久,越看越头晕,尤其是内部的循环和递归调用
精彩评论