国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 一個(gè)函數(shù)看不太懂,求指點(diǎn)?

瀏覽:110日期:2023-03-08 15:23:49

問題描述

function choose(arr, size) { var allResult = []; (function (arr, size, result) { var arrLen = arr.length; if (size > arrLen) { return; } if (size == arrLen) { allResult.push([].concat(result, arr)) } else { for (var i = 0; i < arrLen; i++) {var newResult = [].concat(result);newResult.push(arr[i]);if (size == 1) { allResult.push(newResult);} else { var newArr = [].concat(arr); newArr.splice(0, i +  1); arguments.callee(newArr, size - 1, newResult);} } } })(arr, size, []); return allResult;}

問題解答

回答1:

這是一個(gè)應(yīng)用黑魔法的排列組合實(shí)現(xiàn),實(shí)現(xiàn)的功能大致為:

choose([1, 2, 3], 1) 得到 [ [ 1 ], [ 2 ], [ 3 ] ]

choose([1, 2, 3], 2) 得到 [ [ 1, 2 ], [ 1, 3 ], [ 2, 3 ] ]

choose([1, 2, 3, 4], 3) 得到 [ [ 1, 2, 3 ], [ 1, 2, 4 ], [ 1, 3, 4 ], [ 2, 3, 4 ] ]

內(nèi)層的匿名函數(shù)通過 arguments.callee 遞歸地調(diào)用自己,每次遞歸調(diào)自己時(shí) size 參數(shù)均減一,每次的 newResult 都是一個(gè)【長度為總組合個(gè)數(shù),每項(xiàng)元素為當(dāng)前組合】的二維數(shù)組,當(dāng) newResult 中每項(xiàng)長度達(dá)到 size 時(shí),結(jié)束遞歸并返回最后的 result。

回答2:

閉包寫法,防止函數(shù)內(nèi)部參數(shù)受外部影響。

標(biāo)簽: JavaScript
主站蜘蛛池模板: 内乡县| 东明县| 仲巴县| 广丰县| 叙永县| 庆阳市| 石狮市| 饶阳县| 孝感市| 乌兰浩特市| 加查县| 抚松县| 延津县| 宁海县| 化州市| 义乌市| 合山市| 鹤壁市| 临沧市| 灵山县| 新河县| 辽源市| 富顺县| 彭州市| 丰顺县| 兖州市| 天水市| 托里县| 江川县| 北海市| 保德县| 东丰县| 革吉县| 日喀则市| 恩平市| 营山县| 南汇区| 惠东县| 康乐县| 紫云| 绥棱县|