怎样才能做网站,西安网站开发服务多少钱,充值网站建设,毕业设计资料网站有哪些#x1f49d;#x1f49d;#x1f49d;欢迎来到我的博客#xff0c;很高兴能够在这里和您见面#xff01;希望您在这里可以感受到一份轻松愉快的氛围#xff0c;不仅可以获得有趣的内容和知识#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学… 欢迎来到我的博客很高兴能够在这里和您见面希望您在这里可以感受到一份轻松愉快的氛围不仅可以获得有趣的内容和知识也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学习,不断总结,共同进步,活到老学到老导航 檀越剑指大厂系列:全面总结 java 核心技术点,如集合,jvm,并发编程 redis,kafka,Spring,微服务,Netty 等常用开发工具系列:罗列常用的开发工具,如 IDEA,Mac,Alfred,electerm,Git,typora,apifox 等数据库系列:详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等懒人运维系列:总结好用的命令,解放双手不香吗?能用一个命令完成绝不用两个操作数据结构与算法系列:总结数据结构和算法,不同类型针对性训练,提升编程思维,剑指大厂 非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。 ✨✨ 欢迎订阅本专栏 ✨✨ 博客目录 给你一个字符串数组请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 示例一: 输入: strs [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”] 输出: [[“bat”],[“nat”,“tan”],[“ate”,“eat”,“tea”]] 示例二: 输入: strs [“”] 输出: [[“”]] 示例三: 输入: strs [“a”] 输出: [[“a”]] 解法 1:使用 HashMap 进行存储数据和 putIfAbsent 的使用
public ListListString groupAnagrams(String[] strs) { // 6msHashMapString, ListString map new HashMap();for (String str : strs) {final char[] chars str.toCharArray();Arrays.sort(chars);String key new String(chars);map.putIfAbsent(key, new ArrayList());map.get(key).add(str);}return new ArrayList(map.values());
}解法 2:
computeIfAbsent 的使用
public ListListString groupAnagrams(String[] strs) {HashMapString, ListString map new HashMap();for (String str : strs) {char[] chars str.toCharArray();Arrays.sort(chars);String key new String(chars);ListString strings map.computeIfAbsent(key, k - new ArrayList());strings.add(str);}return new ArrayList(map.values());
}解法 3
static class ArrayKey {int[] key new int[26];public ArrayKey(String str) {for (int i 0; i str.length(); i) {char ch str.charAt(i);key[ch - a];}}Overridepublic boolean equals(Object o) {if (this o) return true;if (o null || getClass() ! o.getClass()) return false;ArrayKey arrayKey (ArrayKey) o;return Arrays.equals(key, arrayKey.key);}Overridepublic int hashCode() {return Arrays.hashCode(key);}
}public ListListString groupAnagrams(String[] strs) {HashMapArrayKey, ListString map new HashMap();for (String str : strs) {ListString strings map.computeIfAbsent(new ArrayKey(str), k - new ArrayList());strings.add(str);}return new ArrayList(map.values());
}觉得有用的话点个赞 呗。 ❤️❤️❤️本人水平有限如有纰漏欢迎各位大佬评论批评指正 如果觉得这篇文对你有帮助的话也请给个点赞、收藏下吧非常感谢! Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧