力扣知识点杂集

  • 无序哈希表(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);
相关推荐
不爱吃炸鸡柳1 小时前
单链表专题(完整代码版)
数据结构·算法·链表
CylMK1 小时前
题解:AT_abc382_d [ABC382D] Keep Distance
算法
Dfreedom.1 小时前
计算机视觉全景图
人工智能·算法·计算机视觉·图像算法
Morwit2 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣2 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先
无小道2 小时前
算法——暴力+优化
算法·优化·暴力
Free Tester2 小时前
如何判断 LeakCanary 报告的严重程度
java·jvm·算法
zyq99101_13 小时前
DFS算法实战:经典例题代码解析
python·算法·蓝桥杯·深度优先
智者知已应修善业3 小时前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机
广州灵眸科技有限公司3 小时前
为RK3588注入澎湃算力:RK1820 AI加速卡完整适配与评测指南
linux·网络·人工智能·物联网·算法