JavaScriptでの2次元配列のグループ化と並べ替え
このような数の2次元配列があるとします-
const arr = [ [1, 3, 2], [5, 2, 1, 4], [2, 1] ];
すべての同じ番号を独自の個別のサブ配列にグループ化するJavaScript関数を作成する必要があります。次に、関数はグループ配列を並べ替えて、サブ配列を昇順で配置する必要があります。
したがって、最終的に新しい配列は次のようになります-
const output = [ [1, 1, 1], [2, 2, 2], [4], [3], [5] ];
例
このためのコードは-
になりますconst arr = [ [1, 3, 2], [5, 2, 1, 4], [2, 1] ]; const groupAndSort = arr => { const res = []; const map = Object.create(null); Array.prototype.forEach.call(arr, item => { item.forEach(el => { if (!(el in map)) { map[el] = []; res.push(map[el]); }; map[el].push(el); }); }); res.sort((a, b) => { return a[0] - b[0]; }); return res; }; console.log(groupAndSort(arr));
出力
コンソールの出力-
[ [ 1, 1, 1 ], [ 2, 2, 2 ], [ 3 ], [ 4 ], [ 5 ] ]
-
JavaScriptを使用して配列の差の合計を並べ替えて見つける
問題 整数の配列を受け取るJavaScript関数を作成する必要があります。この関数は、配列内の連続するペア間の差を降順で合計する必要があります。 例-配列が-の場合 [6, 2, 15] その場合、出力は-になります。 (15 - 6) + (6 - 2) = 13 例 以下はコードです- const arr = [6, 2, 15]; const sumDifference = (arr = []) => { const descArr = arr.sort((a, b) => b - a); if (descArr.
-
JavaScriptでの2次元配列の再形成
問題 最初の引数として数値の2次元配列arrを取り、行を表す2つの数値rとcを受け取るJavaScript関数を作成する必要があります。 番号と列 それぞれ、目的の行列の番号。 この関数は、同じ行トラバース内に指定された行と列を持つ新しい2次元配列を形成して返す必要があります 入力配列にあったとおりに並べ替えます。 たとえば、関数への入力が-の場合 const arr = [ [6, 7], [8, 9] ]; const r = 1, c = 4; その場合、出力は-になります。 const output = [[6, 7, 8,