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. したがって、マップ構造を定義し、アナグラムである文字列を同じキーの下に置く必要があります。
  3. このキーは、文字列をソートするか、文字列の 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());
};

問題リンク#

アナグラムのグループ化

読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。