哈希集合-----从零开始的数据结构学习

一. 定义

"哈希集合 " 是一种基于哈希表实现的无序集合,用于存储互不相同的元素,支持高效的插入、删除和查找操作(平均 O(1) 时间复杂度)。

哈希表的键实际上 就是 "哈希集合"

哈希集合中,哈希标的元素不处理,用bool值来代替(或者说来判断)----占位符

二.代码:

cpp 复制代码
#include<iostream>
#include<unordered_map>
using namespace std;

template<typename K>
class MyhashSet{
private:
    unordered_map<K,bool> map;

public:
    void add(const K& key){
        map[key] = true;
    }

    void remove(const K& key){
        map.erase(key);
    }

    bool contains(const K& key){
        return map.find(key) != map.end();
    }

    int size()const{
        return map.size();
    }
};

本质上: 操纵哈希集合,就是操纵哈希表的键。

三. stl 哈希集合

unordered_set<数据类型> 变量名

详细请看:STL---常见数据结构总结-CSDN博客

相关推荐
谭欣辰26 分钟前
LCS(最长公共子序列)详解
开发语言·c++·算法
m0_6294947331 分钟前
LeetCode 热题 100-----17.缺失的第一个正数
数据结构·算法·leetcode
Cando学算法31 分钟前
鸽笼原理(抽屉原理)
c++·算法·学习方法
Tisfy36 分钟前
LeetCode 0796.旋转字符串:暴力模拟
算法·leetcode·题解·模拟·字符串匹配
BlockChain8881 小时前
AI+区块链深度探索:算法与账本的共生时代
人工智能·算法·区块链
生成论实验室1 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第一章 源:不可言说的生成之源
人工智能·科技·算法·生活·创业创新
2zcode1 小时前
基于低光照增强与轻量型CNN道路实时识别算法研究(UI界面+数据集+训练代码)
人工智能·算法·cnn·低光照增强·自动驾驶技术
hnjzsyjyj2 小时前
洛谷 P1443:马的遍历 ← BFS
数据结构·bfs
小雅痞2 小时前
[Java][Leetcode middle] 209. 长度最小的子数组
java·算法·leetcode
做时间的朋友。2 小时前
精准核酸检测
java·数据结构·算法