当前位置: 首页 > news >正文

算法 ---哈希表

一、哈希介绍

是什么

存储数据的容器

什么用

快速查找某个元素

什么时候用哈希表

频繁的查找某一个数的时候

怎么用哈希表

(1)容器(哈希表)

(2)用数组模拟哈希表(字符串的字符,数据范围很小的时候)

二、题目

1、两数之和

两数之和

(1)题目

(2)解题思路

解题思路一:双指针,遍历整个数组,把符合条件的返回

解题思路二:用哈希表,将数组下标和值存起来,在遍历数组的时候,在哈希表中寻找目标值和当前遍历的值的差值

(3)代码实现

解法一:

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {for(int i = 0; i<nums.size(); i++){for(int j = i+1; j<nums.size(); j++){if(nums[i]+nums[j]==target){return{i,j};}}}return {-1,-1};}
};

class Solution 
{
public:vector<int> twoSum(vector<int>& nums, int target) {for(int i = 0; i<nums.size();i++){for(int j = 0; j<i;j++){if(nums[i]+nums[j] == target){return {i,j};}}}  return {-1,-1}; }
};

解法二:

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {unordered_map<int,int> hash;for(int i = 0 ; i<nums.size();i++){int t = target - nums[i] ;if(hash.count(t)){return {hash[t], i};}hash[nums[i]] = i;}return {-1,-1};}
};

2、判断数组是否重排

 判断数组是否重排

 (1)题目

(2)解题思路

我们可以用数组模拟哈希表,开一个数为26的数组,首先遍历其中一个字符串将每一个字母-'0'的位置--,然后再遍历另外一个字符串将每一个字母的-'0'的字母++,最后遍历数组如果存在不是0的数就不是重排

(3)代码书写

class Solution 
{
public:bool CheckPermutation(string s1, string s2) {if(s1.size()!=s2.size()){return false;}int nums[26]={0};for(int i = 0; i < s1.size(); i++){nums[s1[i]-'a']++; nums[s2[i]-'a']--; }for(int j = 0; j<26;j++){if(nums[j]!=0)return false;}return true;}
};

3、存在重复元素

存在重复元素

(1)题目

 (2)解题思路

       我们创立一个哈希表,遍历nums,如果存在数组中的值则返回true,不存在数组中的则插入

(3)代码实现

class Solution 
{
public:bool containsDuplicate(vector<int>& nums) {unordered_set<int> hash;for(auto x: nums)if(hash.count(x))return true;else hash.insert(x);return false;}
};

4、存在重复元素二

存在重复元素二

 (1)题目

(2)解题思路

   创建一个哈希表,遍历nums如果哈希表中存在该下标的值,判断该下标和原先所存储的小表达差值是否小于k,如果是,返回true,否则覆盖下标,如果哈希表中部存在该下标的值,则插入

(3)代码实现

class Solution 
{
public:bool containsNearbyDuplicate(vector<int>& nums, int k) {unordered_map<int , int> hash;for(int i = 0 ; i<nums.size(); i++){if(hash.count(nums[i])) {if(i - hash[nums[i]]<=k){return true;}else{hash[nums[i]] = i;}}else{hash[nums[i]] = i;}}return false;}
};

5、字母异位词分组

字母异位词分组

(1)题目

 

(2)解题思路

我们可以创立一个哈希表string ,vector<string> 然后遍历strs,将他的值排序后如果hash表中含有,插入到vector<string>中

(3)代码实现

class Solution {
public:vector<vector<string>> groupAnagrams(vector<string>& strs) {unordered_map<string ,vector<string>> hash;for(auto&e: strs){string tmp = e;sort(tmp.begin(),tmp.end());hash[tmp].push_back(e);}vector<vector<string>> ret;for(auto &[x,y] : hash){ret.push_back(y);}return ret;}};

http://www.dtcms.com/a/346815.html

相关文章:

  • 从0到1:数据库进阶之路,解锁SQL与架构的奥秘
  • 日语学习-日语知识点小记-进阶-JLPT-N1阶段蓝宝书,共120语法(6):51-60语法
  • 为什么存入数据库的中文会变成乱码
  • 从罗永浩访谈李想中学习现代家庭教育智慧
  • C++编程语言:标准库:第36章——字符串类(Bjarne Stroustrup)
  • 【秋招笔试】2025.08.23美团研发岗秋招笔试题
  • 超越基础:Glide 高级优化与自定义实战
  • 氟锑酸与氢氧化铯的反应:从化学原理到计算模拟
  • Science Robotics 通过人机交互强化学习进行精确而灵巧的机器人操作
  • 文生3D实战:用[灵龙AI API]玩转AI 3D模型 – 第7篇
  • 【C标准库】详解<stdio.h>标准输入输出库
  • 数字化转型模型工作手册
  • 一种解决使用 PotPlayer 播放 Alist 的 Webdav 时提示 无法在 FTP/WebDAV/HTTP 上修改该文件夹 的方法
  • 深入理解纹理与QtOpenGL的实现
  • 随着威胁的加剧,地方政府难以保卫关键基础设施
  • 【小沐学GIS】基于C++绘制三维数字地球Earth(osgEarth、三维瓦片地球)第十期
  • 2025年AI Agent规模化落地:企业级市场年增超60%,重构商业作业流程新路径
  • 基于Labview的旋转机械AI智能诊断系统
  • docker:compose
  • 科技赋能,宁夏农业绘就塞上新“丰”景
  • 前端 H5分片上传 vue实现大文件
  • vue实现小程序oss分片上传
  • 2025年Java在中国开发语言排名分析报告
  • AI Common Notify :统一 AI 编程工具通知的小工具
  • LLM - Agent核心架构:四大“身体”部件
  • 【Spring Boot】集成Redis超详细指南 Redis在Spring Boot中的应用场景
  • GEO优化服务:智能时代营销新赛道的中国引领者——全球行业格局与发展趋势观察
  • react相关知识
  • 鸿蒙中内存泄漏分析
  • 爬虫基础学习-robots协议,以及request各种请求方式的实操