力扣知识点杂集

  • 无序哈希表(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);
相关推荐
We་ct4 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程8 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮9 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说9 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove10 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung10 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了10 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL10 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰11 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商11 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法