LeetCode-哈希表专题

1.两数相加

  1. two-sum(easy)
    Leetcode

解法1:双重循环

class Solution {
    public int[] twoSum(int[] nums, int target) {

        for(int i=0;i<nums.length;i++){
            int temp = target - nums[i];
            for(int j=i+1;j<nums.length;j++){
                if(temp == nums[j]){
                    return new int[]{i,j};
                }
            }
        }
        return new int[]{};
    }
}

解法2:利用HashMap,将值作为key,索引作为value,存入Map,
循环遍历数组,当Map中的key是target-nums[i]的值的时候,返回当前的i和那个key的value

class Solution {
    public int[] twoSum(int[] nums, int target) {
        HashMap<Integer, Integer> indexForNum = new HashMap<>();
        for(int i=0;i<nums.length;i++){
            if(indexForNum.containsKey(target-nums[i])){
                return new int[]{indexForNum.get(target-nums[i]),i};
            }else{
                indexForNum.put(nums[i],i);
            }
        }
        return null;
    }
}

2.存在重复元素

  1. contains-duplicate(easy)
    Leetcode

解法1:HashMap,判断是否包含当前值的key

class Solution {
    public boolean containsDuplicate(int[] nums) {
        HashMap m = new HashMap();
        for(int i=0;i<nums.length;i++){
            if(m.containsKey(nums[i])){
                return true;
            }else{
                m.put(nums[i],i);
            }
        }
        return false;
    }
}

解法2:HashSet,直接比较结束后的Set长度和nums的长度

class Solution {
    public boolean containsDuplicate(int[] nums) {
        HashSet s = new HashSet();
        for(int i=0;i<nums.length;i++){
            s.add(nums[i]);
        }
        return s.size()<nums.length;
    }
}

3.最长和谐序列

  1. Longest Harmonious Subsequence (Easy)
    Leetcode

解法1:双重循环
解法2:将数组放到hashMap中,扫描一遍HashMap

class Solution {
    public int findLHS(int[] nums) {
        HashMap<Integer,Integer> m = new HashMap();
        for(int num : nums){
            m.put(num, m.getOrDefault(num, 0) + 1);
        }
        int res = 0;
        for(int key : m.keySet()){
            if(m.containsKey(key+1)){
                res = Math.max(res,m.get(key)+m.get(key+1));
            }
        }
        return res;
    }
}
全部评论

相关推荐

2025-12-28 20:47
已编辑
北京工商大学 Java
程序员牛肉:我靠你这个实习经历其实最需要担心的点是你做的太多了,可能会被面试官怀疑是你伪造的。 交易状态机是你做的,支付多渠道是你做的,对账是你做的,结算还是你做的,重复支付也是你做的,整个服务的异常处理也是你做的。 其实你这个反而问题很大的,你想想站在面试官的角度,他是真的会相信你的能力很强,还是相信这份实习你伪造了大部分?我相信你真的做了这么多,但是删一些,废话删一删。你这个做的太多了反而真实性不可信。 后面再补一个项目,在github上找一个高star的项目学一学然后写到自己简历上。我觉得你能力肯定没问题。28届能做到这个份上很厉害,但是在求职市场中,你不是在跟28届的同学比,把你这个简历放到27届其实也就一般水平。 所以后续要想一想看看能不能给自己简历上搞点亮点,比如开源贡献呢?比如博客呢?
实习要如何选择和准备?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务