【力扣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;
    }
};
相关推荐
Liangwei Lin4 小时前
LeetCode 287. 寻找重复数
算法·leetcode·职场和发展
OCR_133716212754 小时前
护照OCR校验位技术解析:从算法逻辑到工程落地,筑牢证件核验安全线
人工智能·算法
Hello.Reader4 小时前
算法基础(十三)——随机算法为什么有时主动引入随机性
java·数据库·算法
老鱼说AI5 小时前
现代 LangChain 开发指南:从 LCEL 原理到企业级 RAG 与 Agent 实战
java·开发语言·人工智能·深度学习·神经网络·算法·机器学习
小许同学记录成长5 小时前
基于幅度形态与参数聚类的工作模式判别
python·算法·scikit-learn
gumichef5 小时前
二叉树_堆
算法
Liangwei Lin5 小时前
LeetCode 70. 爬楼梯
算法
洛水水6 小时前
【力扣100题】38.路径总和 III
算法·leetcode·深度优先
小侯不躺平.6 小时前
C++ Boost库【2】 --stringalgo字符串算法
linux·c++·算法
流年如夢6 小时前
二叉树详解
c语言·数据结构·算法