news 2026/4/27 23:09:48

C++学习记录-旧题新做-堆盘子

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++学习记录-旧题新做-堆盘子

旧题记录:

https://blog.csdn.net/chamao_/article/details/143775934?fromshare=blogdetail&sharetype=blogdetail&sharerId=143775934&sharerefer=PC&sharesource=chamao_&sharefrom=from_link

C++解法:

class StackOfPlates { private: vector<vector<int>> stacks; int cap; public: StackOfPlates(int cap) { this -> cap = cap; } void push(int val) { if (cap == 0) return; if (stacks.empty() || stacks.back().size() == cap) { stacks.push_back(vector<int>()); } stacks.back().push_back(val); } int pop() { if (stacks.empty()) return -1; int val = stacks.back().back(); stacks.back().pop_back(); if (stacks.back().empty()) { stacks.pop_back(); } return val; } int popAt(int index) { if (index < 0 || index >= stacks.size() || stacks[index].empty()) return -1; int val = stacks[index].back(); stacks[index].pop_back(); if (stacks[index].empty()) { stacks.erase(stacks.begin() + index); } return val; } }; /** * Your StackOfPlates object will be instantiated and called as such: * StackOfPlates* obj = new StackOfPlates(cap); * obj->push(val); * int param_2 = obj->pop(); * int param_3 = obj->popAt(index); */

今天来了解vector的常用接口:

一、vector 是什么(一句话)

std::vector<T>

👉动态连续数组

  • 内存连续

  • 支持随机访问O(1)

  • 尾部插入 / 删除高效


二、容量 & 状态相关(非常常用)

1️⃣ size()

v.size();

  • 返回当前元素个数

  • 类型是size_t(无符号)

⚠️ 注意:

for (int i = 0; i < v.size(); ++i) // 潜在警告

更安全:

for (size_t i = 0; i < v.size(); ++i)


2️⃣ empty()

v.empty();

  • 是否为空

  • size() == 0更语义化


3️⃣ capacity()

v.capacity();

  • 当前分配的最大容量

  • ≥ size()


4️⃣ reserve(n)

v.reserve(100);

  • 提前分配内存

  • 避免频繁扩容(性能优化)

⚠️ 不改变 size!


5️⃣ resize(n)

v.resize(5);

  • 改变size

  • 扩大 → 用默认值填充

  • 缩小 → 多余元素被销毁


三、元素访问(刷题必会)

6️⃣ operator[]

v[i];

  • O(1)

  • 不做越界检查(最快)


7️⃣ at()

v.at(i);

  • 越界会抛std::out_of_range

  • 调试时更安全


8️⃣ front() / back()

v.front(); // 第一个 v.back(); // 最后一个

⚠️ vector 不能为空!


9️⃣ data()

int* p = v.data();

  • 返回底层连续内存指针

  • 可与 C API / memcpy 交互


四、修改元素(核心操作)

🔟 push_back()

v.push_back(x);

  • 尾插

  • 均摊 O(1)


1️⃣1️⃣ emplace_back()

v.emplace_back(1, 2);

  • 原地构造

  • 避免临时对象(性能更优)


1️⃣2️⃣ pop_back()

v.pop_back();

  • 删除最后一个

  • 不返回值


1️⃣3️⃣ insert()

v.insert(v.begin() + i, x);

  • 在任意位置插入

  • O(n)(元素搬移)


1️⃣4️⃣ erase()

v.erase(v.begin() + i);

或区间:

v.erase(v.begin(), v.begin() + 3);

  • 删除元素

  • 后续元素前移


1️⃣5️⃣ clear()

v.clear();

  • 清空所有元素

  • capacity 不变


五、迭代器相关(工程 & STL 算法)

1️⃣6️⃣ begin() / end()

for (auto it = v.begin(); it != v.end(); ++it) { ... }


1️⃣7️⃣ rbegin() / rend()

for (auto it = v.rbegin(); it != v.rend(); ++it) { ... }


1️⃣8️⃣ cbegin() / cend()

for (auto it = v.cbegin(); it != v.cend(); ++it) { ... }

  • 返回const_iterator


六、赋值 & 构造相关

1️⃣9️⃣ 构造函数

vector<int> v1; // 空 vector<int> v2(5); // 5 个 0 vector<int> v3(5, 3); // 5 个 3 vector<int> v4 = {1,2,3}; // 初始化列表 vector<int> v5(v4); // 拷贝构造


2️⃣0️⃣ assign()

v.assign(5, 10); // 5 个 10


2️⃣1️⃣ swap()

v1.swap(v2);

  • O(1)

  • 常用于快速清空内存

vector<int>().swap(v);

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/24 5:45:30

服务器卡了还在跑机房?DashDot + cpolar,手机躺看监控数据

DashDot 是一款轻量级服务器监控工具&#xff0c;能实时展示 CPU、内存、存储、网络等状态&#xff0c;界面有赛博朋克风和极简白两种主题&#xff0c;数据可视化做得很直观。它适合运维人员、个人服务器用户&#xff0c;甚至 NAS 玩家 —— 不用像 Prometheus 那样配置复杂&am…

作者头像 李华
网站建设 2026/4/17 0:33:29

VIT位置编码缺陷:影响OCR细粒度识别的原因

VIT位置编码缺陷&#xff1a;影响OCR细粒度识别的原因 &#x1f4d6; OCR文字识别的技术演进与挑战 光学字符识别&#xff08;OCR&#xff09;作为连接物理世界与数字信息的关键技术&#xff0c;广泛应用于文档数字化、票据处理、智能交通等领域。随着深度学习的发展&#xff0…

作者头像 李华
网站建设 2026/4/15 17:26:19

ZLMediaKit录制功能终极指南:5分钟快速构建专业视频录制系统

ZLMediaKit录制功能终极指南&#xff1a;5分钟快速构建专业视频录制系统 【免费下载链接】ZLMediaKit 项目地址: https://gitcode.com/gh_mirrors/zlm/ZLMediaKit 想要构建一个功能强大的流媒体服务器录制系统&#xff1f;ZLMediaKit录制功能正是您需要的完美解决方案&…

作者头像 李华
网站建设 2026/4/23 15:52:51

Wan2.1-FLF2V:开启AI视频创作新纪元的全能工具

Wan2.1-FLF2V&#xff1a;开启AI视频创作新纪元的全能工具 【免费下载链接】Wan2.1-FLF2V-14B-720P-diffusers 项目地址: https://ai.gitcode.com/hf_mirrors/Wan-AI/Wan2.1-FLF2V-14B-720P-diffusers Wan2.1-FLF2V-14B-720P-diffusers是一款革命性的AI视频生成工具&am…

作者头像 李华
网站建设 2026/4/16 22:56:08

Terrapin-Scanner:终极SSH安全漏洞检测指南

Terrapin-Scanner&#xff1a;终极SSH安全漏洞检测指南 【免费下载链接】Terrapin-Scanner This repository contains a simple vulnerability scanner for the Terrapin attack present in the paper "Terrapin Attack: Breaking SSH Channel Integrity By Sequence Numb…

作者头像 李华
网站建设 2026/4/27 18:09:50

QODER插件 vs 传统开发:效率提升对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 设计一个效率对比工具&#xff0c;展示使用QODER插件和传统方法完成相同编程任务的耗时差异。包括代码生成、调试和部署的各个环节&#xff0c;生成可视化报告。点击项目生成按钮&…

作者头像 李华