banner
Koresamuel

Koresamuel

Sometimes ever, sometimes never.
github
twitter
email

49. 字母異位詞分組

题目描述#

給你一個字串陣列,請將 字母異位詞 組合在一起。可以按任意順序返回結果列表。

字母異位詞 是由重新排列源單詞的所有字母得到的一個新單詞。

示例 1:

輸入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
輸出: [["bat"],["nat","tan"],["ate","eat","tea"]]

示例 2:

輸入: strs = [""]
輸出: [[""]]

示例 3:

輸入: strs = ["a"]
輸出: [["a"]]

提示:

1 <= strs.length <= 10^4
0 <= strs[i].length <= 100
strs [i] 僅包含小寫字母

思路#

  1. 互為字母異位詞的字串所包含的字母一定是一樣的,只是順序不一致
  2. 那只需要定義一個 map 結構,把互為字母異位詞的字串放到同一個 key 下面
  3. 而這個 key,我們可以將字串排序或者取字串的 charcode 值的和,或者計數字元個數的字串都行

题解#

/**
 * @param {string[]} strs
 * @return {string[][]}
 */
var groupAnagrams = function(strs) {
  if (strs.length === 1) return [strs];
  const m = new Map();
  for (let i = 0; i < strs.length; i++) {
    const temp = strs[i].split('').sort().join('');
    // or const temp = Array.from(strs[i]).reduce((acc, curr) => acc + curr.charCodeAt(), 0);
    if (m.has(temp)) {
      m.set(temp, [...m.get(temp), strs[i]]);
    } else {
      m.set(temp, [strs[i]]);
    }
  }
  return Array.from(m.values());
};

题目链接#

字母異位詞分組

載入中......
此文章數據所有權由區塊鏈加密技術和智能合約保障僅歸創作者所有。