Given an array of strings, group anagrams together.
For example, given: ["eat", "tea", "tan", "ate", "nat", "bat"]
,
Return:
[ ["ate", "eat","tea"], ["nat","tan"], ["bat"] ]
Note: All inputs will be in lower-case.
遍历一遍strs,碰到的每个字符串后先拆解成字符数组,然后按照字典顺序排序,之后组装为string类型的字符串
判断字符串是否出现在map中,若在,将拆解组装之前的字符串存入相应map 的 list中
map集合中各个key对应的value就是由相同字母组成的字符串
public class Solution { //第一次 一次提交 一次AC public List<List<String>> groupAnagrams(String[] strs) { List<List<String>> ansli = new ArrayList<List<String>>(); HashMap<String,List<String>> map = new HashMap<String,List<String>>(); for(int i=0;i<strs.length;i++){ char [] c = strs[i].toCharArray(); Arrays.sort(c); String str = String.valueOf(c); if( map.containsKey(str) ){ List<String> list = map.get( str ); list.add( strs[i] ); } else{ List<String> list = new ArrayList<String>(); ansli.add(list); //既然对于应用型数据添加的应用的地址,添加之后对于应用的修改,对所有有该引用类型的地值 //的,list都有效,就不用在通过遍历map 来实现了,替代了下方注释的部分 list.add( strs[i] ); map.put(str,list); } } //遍历map // Iterator<HashMap.Entry<String, List<String>>> entries = map.entrySet().iterator(); // while (entries.hasNext()) { // Map.Entry<String, List<String>> entry = entries.next(); // ansli.add(entry.getValue()); // } return ansli; } }