数据结构(三)—— 哈希表

news/2025/3/15 0:58:40/

文章目录

  • 一、哈希表积累
    • 1.1 哈希map
    • 1.2 哈希set
  • 二、哈希表基础
  • 三、题
    • 3.1 242 有效的字母异位词
    • 3.2 349 两个数组的交集
    • 3.3 202 快乐数
    • 3.4 1 两数之和
    • 3.5 54 四数相加II


一、哈希表积累

什么时候想到用哈希法:当要需要查询一个元素是否出现过、判断一个元素是否出现在集合中时,考虑哈希法。

1.1 哈希map

1、遍历哈希映射代码

unordered_map<int,int> visited;
for (auto it = visited.begin(); it != visited.end(); ++it){if ((*it).first == key)(*it).second = value;
}

2、寻找哈希映射是否有某一个key值
if(visited.find(temp) != visited.end()) {...} // 说明找到了temp
3、哈希map中key相同的情况
unordered_map<int, int> mymap;
mymap[1] = 1;
mymap[1] = 2; // 这样1会被覆盖,此时mymap[1]为2
4、val为int时默认为0
unordered_map<int, int> mymap;
mymap[a + b]++; 这样是做是可以直接让 mymap[a+b]为1的

1.2 哈希set

1、遍历哈希set代码
for (auto it = windowfalse.begin(); it != windowfalse.end(); it++)
cout << *it << endl;
2、插入值进入哈希set代码

unordered_set<int> hash_set;
hash_set.insert(sum);

3、使用哈希set的erase函数会删除表中所有的相关数
windowfalse.erase(1); // 这会删除哈希set中所有的1,这么说是错的!因为哈希set永远不会有相同的元素!!
4、nums_set中的值为1、2,也就是说哈希set不会有相同的元素

vector<int> nums1 = {1,1,2,2};
unordered_set<int> nums_set(nums1.begin(), nums1.end());

5、查找哈希set是否有目标元素
hash_set.count(a) 找到了返回1
hash_set.find(sum) == hash_set.end() 找到了end()则说明没找到

二、哈希表基础

在这里插入图片描述
索引为key,元素为val,组成键值对
要枚举的话时间复杂度是O(n),但如果**使用哈希表只需要O(1)**就可以做到。

三、题

3.1 242 有效的字母异位词

记住哈希表的遍历方式

unordered_map<char,int> visited;for (auto it = visited.begin(); it != visited.end(); ++it){if ((*it).second != 0)return false;
}

3.2 349 两个数组的交集

vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {vector<int> res;unordered_map<int,int> visited;for(int i=0; i < nums1.size(); i++){if(visited[nums1[i]] == 0)   // 重要!重复元素只加一次visited[nums1[i]]++;}for(int i=0; i < nums2.size(); i++){visited[nums2[i]]--;if(visited[nums2[i]] == 0)res.push_back(nums2[i]);}return res;
}

3.3 202 快乐数

重点:可能会无限循环,所以需要判断元素是否出现过,使用哈希set
unordered_set<int> hash_set;
hash_set.insert(sum) // 将值插入哈希set
if(hash_set.find(sum) != set.end()) {...} // 判断元素是否出现

class Solution {
public:int computesum(int n){int sum = 0;while(n){int temp = n%10;n = n/10;sum += temp * temp;}return sum;}bool isHappy(int n) {int sum = 0;unordered_set<int> set;while(1){sum = computesum(n);if(sum == 1){return true;}if(set.find(sum) != set.end()){return false;}else{set.insert(sum);}n = sum;}}
};

3.4 1 两数之和

vector<int> twoSum(vector<int>& nums, int target) {unordered_map<int, int> visited;vector<int> res;for(int i=0; i < nums.size(); i++){//visited[nums[i]] = i;   // 放前面不行,通过不了[3,3]的用例int temp = target - nums[i];if((visited.find(temp) != visited.end()) && i > 0){res.push_back(i);res.push_back(visited[temp]);break;}visited[nums[i]] = i;   // 这个放后面,很弱智的逻辑问题}return res;
}

3.5 54 四数相加II

题目:给你四个整数数组 nums1、nums2、nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足:nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0

用例1:
输入:nums1 = [1,2], nums2 = [-2,-1], nums3 = [-1,2], nums4 = [0,2]
输出:2
解释:
两个元组如下:

  1. (0, 0, 0, 1) -> nums1[0] + nums2[0] + nums3[0] + nums4[1] = 1 + (-2) + (-1) + 2 = 0
  2. (1, 1, 0, 0) -> nums1[1] + nums2[1] + nums3[0] + nums4[0] = 2 + (-1) + (-1) + 0 = 0
int fourSumCount(vector<int>& A, vector<int>& B, vector<int>& C, vector<int>& D) {unordered_map<int, int> umap; //key:a+b的数值,value:a+b数值出现的次数// 遍历大A和大B数组,统计两个数组元素之和,和出现的次数,放到map中for (int a : A) {for (int b : B) {umap[a + b]++;}}int count = 0; // 统计a+b+c+d = 0 出现的次数// 在遍历大C和大D数组,找到如果 0-(c+d) 在map中出现过的话,就把map中key对应的value也就是出现次数统计出来。for (int c : C) {for (int d : D) {if (umap.find(0 - (c + d)) != umap.end()) {count += umap[0 - (c + d)];}}}return count;}


http://www.ppmy.cn/news/48080.html

相关文章

从单兵作战到生态共创,纵目科技打响智驾2.0新战役

4月18日&#xff0c;第十二届上海国际汽车工业展览会&#xff08;简称&#xff1a;2023上海车展&#xff09;在上海国家会展中心盛大启幕。纵目科技携最新自动驾驶解决方案——Amphiman 3000、8000行泊一体解决方案、Trinity 3000、8000舱行泊一体解决方案以及众多摄像头产品强…

C++智能指针unique_ptr

智能指针的设计思路 智能指针是类模板&#xff0c;在栈上创建智能指针对象。把普通指针交给智能指针对象。当智能指针对象过期时&#xff0c;调用析构函数释放普通指针的内存。 有unique_ptr,shared_ptr和weak_ptg三种智能指针 unique_ptr unique_ptr独享它指向的对象&…

深度学习笔记之残差网络(ResNet)

深度学习笔记之残差网络[ResNet] 引言引子&#xff1a;深度神经网络的性能问题核心问题&#xff1a;深层神经网络训练难残差网络的执行过程残差网络结构为什么能够解决核心问题残差网络的其他优秀性质 引言 本节将介绍残差网络( Residual Network,ResNet \text{Residual Netwo…

【nacos配置中心】源码部分解析

启动初始化 SpringApplication.prepareContext applyInitializers 回调ApplicationContextInitializer的initialize方法 getInitializers()从applicationContext获取List<ApplicationContextInitializer<?>> initializers 这个集合是通过SpringApplication的…

第三十二章 配置镜像 - 编辑或删除故障转移成员

文章目录 第三十二章 配置镜像 - 编辑或删除故障转移成员编辑或删除故障转移成员 第三十二章 配置镜像 - 编辑或删除故障转移成员 编辑或删除故障转移成员 导航至编辑镜像页面(系统管理>配置>镜像设置>编辑镜像)。使用备份故障转移成员上的删除镜像配置按钮将其从镜…

ChatGpt API接口编程基础与使用

在研读完OpenAi官网文档的基础上&#xff0c;本文大部分内容是围绕编程方面&#xff0c;包括ChatGPT模型接口、图像生成接口、敏感数据拦截等&#xff0c;只有一小部分内容围绕如何通过temperature调参优化使用提示技巧。 一、OpenAi Api调用库 OpenAi开放了一系列模型接口API…

AUTOSAR存储服务之FEE换页策略介绍

概述 如下图是AUTOSAR Memory Stack的架构图,对于Memory Stack的介绍请参考AUTOSAR MemoryStack详细介绍_钢琴上的汽车软件的博客-CSDN博客 随着现在MCU携带的内置flash空间越来越大,从成本节省以及方便使用等方面考虑,在产品设计和开发过程中常用Flash EEPROM Emulation技…

Perl学习教程大纲

以下是一个可能的 Perl 学习教程大纲&#xff1a; 一、Perl 简介 Perl 的历史和发展 Perl 的特点和优点 Perl 的应用领域 二、Perl 基础语法 Perl 的变量和数据类型 Perl 的运算符和表达式 Perl 的控制结构&#xff08;if、while、for、foreach 等&#xff09; Perl 的…