const Finallist = [ [“黑色”、“大”、“a”]、 [“黑色”、“大”、“b”]、 [“黑色”、“大”、“c”]、 [“黑色”、“中”、“a”], [“黑色”、“中”、“b”]、 [“黑色”、“中”、“c”]、 [“藍色”、“大”、“a”], [“藍色”、“大”、“b”]、 [“藍色”、“大”、“c”]、 [“藍色”、“中”、“a”]、 [“藍色”、“中”、“b”]、 [“藍色”、“中”、“c”]、 ]</pre> <p><strong>請記得input_array是動態的</strong></p> <p><strong>請告訴我該如何做到這一點</strong></p>
P粉7295188062023-09-07 09:34:40
你可以像這樣做:
const input_array = [ ["black", "blue"], ["large", "medium"], ["a", "b", "c"] ] const getCompinations = array => array.reduce((v, b) => v.reduce((r, g) => [...r, ...b.map(w => [].concat(g, w))], []) ) console.log(getCompinations(input_array))
P粉4492810682023-09-07 00:39:31
看一下這個,可能會有幫助:
const input_array = [ ["black", "blue"], ["large", "medium"], ["a", "b", "c"] //... 是否可以动态添加多行 ]; const mmc = input_array.reduce((e, r) => e * r.length, 1); const finallist = input_array.map((x,i)=>({index:i,arr:x})).reduce((e, r) => { for (var u = 0; u < mmc; u++) e[u] && (!r.arr.some(r => e[u].includes(r)) || e[u].length <= r.index) ? e[u].push(r.arr[u % r.arr.length]) : e.push([r.arr[u % r.arr.length]]); return e.sort(), e }, []);
小心! 在大規模矩陣中可能會導致瀏覽器崩潰。