久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

javascript - 一個函數看不太懂,求指點?

瀏覽:130日期: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:

這是一個應用黑魔法的排列組合實現,實現的功能大致為:

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 ] ]

內層的匿名函數通過 arguments.callee 遞歸地調用自己,每次遞歸調自己時 size 參數均減一,每次的 newResult 都是一個【長度為總組合個數,每項元素為當前組合】的二維數組,當 newResult 中每項長度達到 size 時,結束遞歸并返回最后的 result。

回答2:

閉包寫法,防止函數內部參數受外部影響。

標簽: JavaScript
主站蜘蛛池模板: 北宁市| 绵阳市| 大石桥市| 买车| 海丰县| 江孜县| 齐齐哈尔市| 清原| 辽源市| 新乡县| 措美县| 定安县| 焦作市| 大埔区| 宁陕县| 普兰县| 舒城县| 二连浩特市| 通化市| 南城县| 出国| 开平市| 克什克腾旗| 天津市| 连平县| 高要市| 钟山县| 兴业县| 驻马店市| 遂宁市| 元江| 延长县| 沽源县| 乌拉特中旗| 信丰县| 固始县| 界首市| 临汾市| 玛纳斯县| 安西县| 延安市|