力扣知识点杂集

  • 无序哈希表(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 小时前
分布式系统C++实现
开发语言·c++·算法
不染尘.2 小时前
最短路径之Bellman-Ford算法
开发语言·数据结构·c++·算法·图论
big_rabbit05022 小时前
JVM堆内存查看命令
java·linux·算法
m0_662577972 小时前
C++中的RAII技术深入
开发语言·c++·算法
旖-旎2 小时前
二分查找(点名)(8)
c++·算法·二分查找·力扣
承渊政道2 小时前
【优选算法】(实战体验滑动窗口的奇妙之旅)
c语言·c++·笔记·学习·算法·leetcode·visual studio
lemonth2 小时前
图形推理----
人工智能·算法·机器学习
2401_891482172 小时前
C++代码复杂性分析
开发语言·c++·算法
keep intensify2 小时前
单词搜索-
算法·深度优先