【力扣hot100】哈希专题

1.两数之和

判断是否有两数和等于target,对于每一个数x判断是否还存在target-x且target-x的下标不是x下标即可。

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        int n=nums.size();
        unordered_map<int,int>mp;
        vector<int>ans;
        for(int i=0;i<n;i++){
            mp[nums[i]]=i;
        }
        for(int i=0;i<n;i++){
            if(mp.count(target-nums[i])&&mp[target-nums[i]]>i){
                ans.push_back(i);
                ans.push_back(mp[target-nums[i]]);
                break;
            }
        }
        return ans;
    }
};

49.字母异位词分组

将每一个字符串排序后即可得到键,值是异位词数组。

c++ 复制代码
class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        vector<vector<string>>ans;
        unordered_map<string,vector<string>>mp;
        for(auto str:strs){
            string key=str;
            sort(key.begin(),key.end());
            mp[key].push_back(str);
        }
        for(auto i=mp.begin();i!=mp.end();i++){
            ans.push_back(i->second);
        }
        return ans;
    }
};

128.最长连续序列

该题题目要求要用O(N)的解法,所以不能直接排序。将数组中的所有数插入哈希集合中,对于集合中每一个数x,判断x-1是否存在,不存在则开始找以x为起点的最长连续序列。

c++ 复制代码
class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        unordered_set<int>s(nums.begin(),nums.end());
        int n=nums.size();
        int ans=0;
        for(auto i:s){
            if(s.contains(i-1)){
                continue;
            }
            int j=i+1;
            while(s.contains(j)){
                j++;
            }
            ans=max(ans,j-i);
        }
        return ans;
    }
};
相关推荐
米粒16 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Fuxiao___7 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
Mr_Xuhhh8 小时前
LeetCode hot 100(C++版本)(上)
c++·leetcode·哈希算法
漫随流水8 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
穿条秋裤到处跑9 小时前
每日一道leetcode(2026.03.31):字典序最小的生成字符串
算法·leetcode
CoovallyAIHub11 小时前
VisionClaw:智能眼镜 + Gemini + Agent,看一眼就能帮你搜、帮你发、帮你做
算法·架构·github
CoovallyAIHub11 小时前
低空安全刚需!西工大UAV-DETR反无人机小目标检测,参数减少40%,mAP50:95提升6.6个百分点
算法·架构·github
CoovallyAIHub11 小时前
IEEE Sensors | 湖南大学提出KGP-YOLO:先定位风电叶片再检测缺陷,三数据集mAP均超87%
算法
Yupureki12 小时前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划
副露のmagic12 小时前
数组章节 leetcode 思路&实现
算法·leetcode·职场和发展