掌握常见的容器的用法

最最基础的 STL 用法死记硬背下来**,不然你看任何题解都像看天书。

我现在的情况就是:
算法思路能懂,但 C++ 容器怎么用完全没概念,所以觉得别人代码很玄乎。

不用系统学 STL 全书,只学刷题刚需的那一点点就够了,


一、你只需要掌握 4 个东西

刷题 99% 只用这 4 个:

  1. vector(动态数组)
  2. queue(队列,BFS 专用)
  3. stack(栈,DFS 非递归专用)
  4. unordered_map(哈希表,记录值用)

下面每个只教最核心、必须会的用法,多一个都不讲。


二、vector 必须会的 6 个操作

cpp 复制代码
vector<int> v;
  1. 尾部添加
cpp 复制代码
v.push_back(1);
  1. 访问元素(像数组一样)
cpp 复制代码
int x = v[0];
  1. 看大小
cpp 复制代码
int sz = v.size();
  1. 判断空
cpp 复制代码
if (v.empty()) { ... }
  1. 清空
cpp 复制代码
v.clear();
  1. 遍历
cpp 复制代码
for (int i = 0; i < v.size(); i++)
    cout << v[i];

就这些,没了。


三、queue 必须会的 5 个操作(你那道题全靠它)

cpp 复制代码
queue<int> q;
  1. 入队(放尾巴)
cpp 复制代码
q.push(1);
  1. 看队头(最关键)
cpp 复制代码
int front = q.front();
  1. 删除队头
cpp 复制代码
q.pop();
  1. 判断空
cpp 复制代码
while (!q.empty()) { ... }
  1. 大小
cpp 复制代码
q.size();

固定句式(背下来)

cpp 复制代码
while (!q.empty()) {
    auto now = q.front();
    q.pop();

    // 处理 now

    q.push(子元素);
}

你那道题的 front() pop() 就是这个固定句式,不是技巧,是模板


四、stack 必须会的 5 个操作

cpp 复制代码
stack<int> st;
  1. 入栈
cpp 复制代码
st.push(1);
  1. 看栈顶
cpp 复制代码
int top = st.top();
  1. 删除栈顶
cpp 复制代码
st.pop();
  1. 判空
cpp 复制代码
st.empty();
  1. 大小
cpp 复制代码
st.size();

五、unordered_map 必须会的 3 个操作

cpp 复制代码
unordered_map<int, int> mp;
  1. 存值
cpp 复制代码
mp[key] = value;
  1. 取值
cpp 复制代码
int val = mp[key];
  1. 判断有没有这个 key
cpp 复制代码
if (mp.count(key)) { ... }

你那道题就是用它存「深度 → 最右节点值」。


六、你现在的核心问题一句话说清

你不是不会算法,

没见过 STL 的固定写法,所以觉得别人代码很巧妙。

其实:

  • BFS = queue + front + pop
  • DFS非递归 = stack + top + pop
  • 存结果 = vector
  • 快速查表 = unordered_map

所有算法题解,都是这几句拼起来的。


这些都是刷算法中最基础的一些操作,掌握之后刷题目的时候才不会懵逼.,有时候其实算法里涉及到的都是一些基础的库函数.

相关推荐
浅念-32 分钟前
递归解题指南:LeetCode经典题全解析
数据结构·算法·leetcode·职场和发展·排序算法·深度优先·递归
Kiling_07041 小时前
Java集合进阶:Set与Collections详解
算法·哈希算法
智者知已应修善业1 小时前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
洛水水2 小时前
【力扣100题】33.验证二叉搜索树
算法·leetcode·职场和发展
SimpleLearingAI2 小时前
聚类算法详解
算法·数据挖掘·聚类
刀法如飞3 小时前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
Dlrb12114 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora4 小时前
Python 算法基础篇之集合
python·算法
平行侠5 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完6 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表