在 JavaScript 中,從不同大小的陣列產生組合可能是一項複雜的任務。讓我們探索使用遞歸輔助函數的解決方案。
笛卡爾函數採用任意數量的陣列作為參數,並傳回所有可能組合的陣列。它使用遞歸輔助函數 helper,它迭代數組中的每個元素並將其推送到當前組合的克隆版本。如果目前陣列不是最後一個,它會遞歸呼叫 helper 來產生剩餘陣列的所有組合。
笛卡爾函數可以如下使用:
cartesian([0,1], [0,1,2,3], [0,1,2]);
這將產生所需的組合:
[0,0,0], [0,0,1], [0,0,2], [0,1,0], [0,1,1], [0,1,2], [0,2,0], [0,2,1], [0,2,2]
將此解決方案與一系列數組,只需將數組作為單一參數傳遞給笛卡爾函數即可。輔助函數將自動迭代巢狀數組以產生所有可能的組合。
var data = [[0,1], [0,1,2,3], [0,1,2]]; var combinations = cartesian(data);
以上是如何在 JavaScript 中從多個陣列產生所有組合?的詳細內容。更多資訊請關注PHP中文網其他相關文章!