[Medium] LeetCode JS 30 - 2631. Group By (阵列分组)

2024年3月7日

💎 加入 E+ 成長計畫 如果你喜歡我們的內容,歡迎加入 E+,獲得更多深入的軟體前後端內容

LeetCode 30 Days of JavaScript

本题来自 LeetCode 的 30 天 JacaScript 挑战

2631. Group By (阵列分组)

题目描述

请实践一个阵列操作的方法 groupBy,该方法会让任何阵列呼叫 array.groupBy(fn) 时,获得该阵列分组后的结果。

所谓的阵列分组**,**是指阵列中的每个键都是 fn(arr[i]) 的输出,输出的阵列中,含有原始阵列中具有该键的所有项。

提供的回呼函式 fn 会接受阵列中的项目并传回一个字串类型的键。每个值阵列的顺序,会与阵列中元素出现的顺序相同。任何顺序的键都是可以接受的。

具体如下范例,输入一个有物件的阵列,并且回呼函式是以 item.id 作为判断,所以呼叫完 groupBy(fn) 后,会把 id 做为键,而有该 id 的物件,都会被放到同个阵列做为值,例如有 {"id":"1"} 的会被放在同个阵列。

// 范例
输入:
[
  {"id":"1"},
  {"id":"1"},
  {"id": 2},
],
fn = function (item) {
  return item.id;
}

输出:
{
  "1": [{"id": "1"}, {"id": "1"}],
2”:[{“id”:“2}]
}

解释:
输出来自函式 array.groupBy(fn)
分组方法是从阵列中的每个项目中取得 "id"
有两个 "id"1 的物件。所以将这两个物件都放在第一个阵列中。
有一个 "id"2 的物件。所以该物件被放到第二个阵列中。

本题解答

以下是本题的解答,详细解题思路可以在 E+ 成长计划看到。如果想练习更多题目,推荐可以到 GreatFrontEnd 上练习

解法

Array.prototype.groupBy = function (fn) {
  const grouped = {};

  this.forEach((item) => {
    const key = fn(item);
    if (!grouped[key]) {
      grouped[key] = [];
    }
    grouped[key].push(item);
  });
  return grouped;
};
🧵 如果你想收到最即時的內容更新,可以在 FacebookInstagram 上追蹤我們