搜尋

首頁  >  問答  >  主體

JavaScript教學:使用矩陣建立清單的方法

<p><strong>我有像這樣的吞吐量</strong></p> <pre class="brush:php;toolbar:false;">const input_array= [ [“黑色”、“藍色”]、 [「大」、「中」]、 [“a”、“b”、“c”] //...是否動態可以新增多行 ];</pre> <p><strong>我得到了一個像這樣的吞吐量:</strong></p>
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粉617237727P粉617237727483 天前585

全部回覆(2)我來回復

  • P粉729518806

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

    回覆
    0
  • P粉449281068

    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
    }, []);
    

    小心! 在大規模矩陣中可能會導致瀏覽器崩潰。

    回覆
    0
  • 取消回覆