LeetCode/49. 字母异位词分组
49. 字母异位词分组
给定一个字符串数组,将字母异位词组合在一起。字母异位词指字母相同,但排列不同的字符串。
示例 :
1 | 输入: ["eat", "tea", "tan", "ate", "nat", "bat"] |
说明:
- 所有输入均为小写字母。
- 不考虑答案输出的顺序。
来源:力扣(LeetCode)
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题解:
按照题目的要求,只有字母出现次数完全相同的两个组合,才可以被称为异位词,针对这一点,有两种思路,第一种就是,先对字符进行排序,将排序后的字符数组作为Key,当前字符串作为Value存入一个Map当中,最后返回Map集合中的Values即可;第二种思路是,由于字母出现次数相同,我们可以把每一位字符加起来,其和作为Key,当前字符串为Value,后续操作和第一种思路相同。当前,官方给出的第二种计数思路其实都大同小异,读者可以自行参考。
具体代码如下:
1 | class Solution { |

