面试题 10.02. 变位词组
生活随笔
收集整理的這篇文章主要介紹了
面试题 10.02. 变位词组
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
編寫一種方法,對字符串數組進行排序,將所有變位詞組合在一起。變位詞是指字母相同,但排列不同的字符串。
注意:本題相對原題稍作修改
示例:
輸入: [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”],
輸出:
[
[“ate”,“eat”,“tea”],
[“nat”,“tan”],
[“bat”]
]
說明:
- 所有輸入均為小寫字母。
- 不考慮答案輸出的順序。
解題思路
因為變位詞是指字母相同,但排列不同的字符串。因此我們可以對字符串進行排序,將字符串按字典序排列,而變位詞的字母是相同的,因此排序以后的結果對于所有變位詞應該是相同的。
代碼
class Solution {public List<List<String>> groupAnagrams(String[] strs) {Map<String,List<String>> map=new HashMap<>();for (String str : strs) {char[] c=str.toCharArray();Arrays.sort(c);String s = new String(c);if(!map.containsKey(s)){map.put(s,new ArrayList<>());}map.get(s).add(str);}List<List<String>> res=new ArrayList<>();for (Map.Entry<String, List<String>> entry : map.entrySet()) {res.add(entry.getValue());}return res;} }總結
以上是生活随笔為你收集整理的面试题 10.02. 变位词组的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 剑指 Offer 53 - I. 在排序
- 下一篇: 5815. 扣分后的最大得分