【JAVA算法|hot100】哈希类型题目详解笔记

这里记录刷hot100的思考过程详解,方便后续记忆复习。

题号1

1. 两数之和

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。

你可以按任意顺序返回答案。

具体题解
java 复制代码
class Solution {
    public int[] twoSum(int[] nums, int target) {
        Map<Integer,Integer> hashmap=new HashMap<>();
        int i=0;
        for(int num:nums){
            if(hashmap.containsKey(target-nums[i])){
                return new int[]{i,hashmap.get(target-nums[i])};
            }
            hashmap.put(nums[i],i);
            i++;
        }
        return new int[0];
    }
}
思路解析

通过containsKey查找之前是否存入过target-num[i]

必会知识

1.containsKey函数

2.数组初始化new int[]{x,y}

题号49

49. 字母异位词分组

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

具体题解
java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        Map<String,List<String>> map=new HashMap<>();
        for(String str:strs){
            char[] array=str.toCharArray();
            Arrays.sort(array);
            String key=new String(array);
            List<String> list=map.getOrDefault(key,new ArrayList<String>());
            list.add(str);
            map.put(key,list);
        }
        return new ArrayList<List<String>>(map.values());
    }
}
思路解析

对每个字符串排序,异位词排序后一定相同。

必会知识

1.字符串转为字符数组,toCharArray()

2.字符数组排序,Arrays.sort()

3.字符串可通过字符数组初始化,new String(array)

4.获取原有异位词集合或新集合列表,getOrDefault(key,new ArrayList<String>());

5.只获取hashmap的value值集合,map.values()

题号128

128. 最长连续序列

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n)的算法解决此问题。

具体题解
java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Set<Integer> hashset=new HashSet<>();
        for(int num:nums){
            hashset.add(num);
        }
        int max=0;
        for(int num:hashset){
            if(!hashset.contains(num-1)){
                int currentnum=num;
                int currentmax=1;
                while(hashset.contains(currentnum+1)){
                    currentmax+=1;
                    currentnum+=1;
                }
                max=Math.max(max,currentmax);
            }
        }
        return max;
    }
}
思路解析

先通过hashset去重,然后找到每个连续序列的最开始数字,去遍历计算最长序列。

必会知识

hashset的使用

相关推荐
lee_curry6 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
码途漫谈7 小时前
Easy-Vibe开发篇阅读笔记(四)——前端开发之结合 Agent Skills 美化界面
人工智能·笔记·ai·开源·ai编程
九转成圣8 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
直奔標竿8 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
金銀銅鐵9 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
糖炒栗子03269 小时前
【笔记】高分卫星影像 TIF 切片处理
笔记
Nice_Fold10 小时前
Kubernetes DaemonSet、StatefulSet与Service(自用笔记)
笔记·容器·kubernetes
野生技术架构师10 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
小袁拒绝摆烂11 小时前
多表关联大平层转JSON树形结构
java·json