力扣知识点杂集

  • 无序哈希表(unordered_map):

键:数组中的数值

值:该数值对应的下标

  • 哈希表常见用法
cpp 复制代码
#include <unordered_map>
//头文件

// 声明一个哈希表,键类型为 Key,值类型为 Value
unordered_map<Key, Value> map;

// 声明哈希表示例
unordered_map<int, int> map;               // 最常见:键和值都是整数





//插入元素
// 方法1:使用中括号(会覆盖已存在的键)
map[1] = 100;
map[2] = 200;

// 方法2:使用 insert 函数(不会覆盖已存在的键,会创造一个临时变量)
map.insert({3, 300});
map.insert(make_pair(4, 400));
map.insert(pair<int, int>(5, 500));

// 方法3:使用 emplace(C++11,更高效)
map.emplace(6, 600);




//访问元素
// 方法1:使用中括号(如果键不存在,会自动插入默认值)
int value1 = map[1];           // 存在则返回对应值
int value2 = map[999];         // 不存在会插入键999,值为0(int默认值)

// 方法2:使用 at()(如果键不存在,抛出 out_of_range 异常)
try {
    int value3 = map.at(1);
    int value4 = map.at(999);   // 会抛出异常
} catch (const out_of_range& e) {
    cout << "键不存在" << endl;
}

// 方法3(也可以用来查找):使用 find()(推荐,可以检查是否存在)
auto it = map.find(1);
if (it != map.end()) {
    cout << "找到: " << it->first << " -> " << it->second << endl;
}





//删除元素
// 方法1:根据键删除
map.erase(1);                    // 删除键为1的元素
int n = map.erase(999);          // 返回删除的元素个数(0或1)

// 方法2:根据迭代器删除
auto it = map.find(2);
if (it != map.end()) {
    map.erase(it);               // 删除迭代器指向的元素
}

// 方法3:删除所有元素
map.clear();                     // 清空哈希表
  • 需要快速判断元素是否存在 → 用 unordered_set

需要建立对应关系 → 用 unordered_map

cpp 复制代码
#include <unordered_set>

unordered_set<int> s;

// 插入
s.insert(10);
s.insert(20);

// 查找
if (s.find(10) != s.end()) {
    // 找到了
}

// 删除
s.erase(10);

// 大小
int size = s.size();
bool empty = s.empty();

// 清空
s.clear();

// count函数最常用的两种场景:

// 1. 判断元素是否存在(unordered_set/map)
if (set.count(value)) {
    // 存在
}

// 2. 统计出现次数(vector/string)
int n = count(vec.begin(), vec.end(), value);
相关推荐
一只叁木Meow1 天前
电商 SKU 选择器:用算法实现优雅的用户交互
前端·javascript·算法
代码中介商1 天前
红黑树完全指南:从五条性质到完整插入删除实现
数据结构·算法
JieE2121 天前
反转链表:从双指针到递归,吃透链表反转的核心逻辑
javascript·算法
玖釉-1 天前
旋转图像:从矩阵转置、镜像到坐标变换的系统理解
c++·windows·算法·图形渲染
fengenrong1 天前
20260522
算法
一条大祥脚1 天前
Codeforces Round 1099 (Div. 2) 构造|贪心|图论|还原数组
java·算法·图论
Sheldon Chao1 天前
Lecture 7 基于策略梯度的算法
人工智能·算法·机器学习
始三角龙1 天前
LeetCode hoot 100 -- 缺失的第一个正整数
算法·leetcode·职场和发展
飞Link1 天前
深度解析孪生网络(Siamese Network):从原理、技巧到实战应用
算法·数据挖掘·回归
测试狗科研平台1 天前
洞悉微观电荷流动,VASP计算电荷密度分布
算法·云计算·开源软件