news 2026/5/8 5:05:28

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/5/2 9:51:22

AppSmith革命性实时协作:多用户同时编辑的高效解决方案

AppSmith革命性实时协作&#xff1a;多用户同时编辑的高效解决方案 【免费下载链接】appsmith appsmithorg/appsmith: Appsmith 是一个开源的无代码开发平台&#xff0c;允许用户通过拖拽式界面构建企业级Web应用程序&#xff0c;无需编写任何后端代码&#xff0c;简化了软件开…

作者头像 李华
网站建设 2026/5/4 23:57:12

AG-UI智能应用开发框架:从理论到实践的完整指南

AG-UI智能应用开发框架&#xff1a;从理论到实践的完整指南 【免费下载链接】ag-ui 项目地址: https://gitcode.com/gh_mirrors/agu/ag-ui 当传统架构遇见AI代理&#xff1a;开发者的真实困境 在当前的AI应用开发浪潮中&#xff0c;开发者们面临着一个尴尬的现实&…

作者头像 李华
网站建设 2026/4/29 16:52:41

收藏必备:Agent工程——大模型应用开发的新范式

Agent工程是构建可靠LLM系统的新兴学科&#xff0c;通过构建-测试-发布-观察-优化-循环迭代&#xff0c;结合产品思维、工程和数据科学技能&#xff0c;解决大模型应用的不可预测性问题&#xff0c;让开发者能够在大模型环境中快速迭代&#xff0c;打造可信赖的智能系统。如果你…

作者头像 李华
网站建设 2026/5/7 6:21:38

告别频道混乱:一站式直播源管理解决方案

告别频道混乱&#xff1a;一站式直播源管理解决方案 【免费下载链接】allinone_format 本项目是对 https://hub.docker.com/r/youshandefeiyang/allinone /tv.m3u、/tptv.m3u、/migu.m3u 进行聚合 & 重新分组。 项目地址: https://gitcode.com/gh_mirrors/al/allinone_fo…

作者头像 李华
网站建设 2026/5/2 18:20:02

语音合成国际化:支持多语言扩展的可能性

语音合成国际化&#xff1a;支持多语言扩展的可能性 &#x1f30d; 技术背景与演进趋势 随着全球化数字内容的快速增长&#xff0c;语音合成&#xff08;Text-to-Speech, TTS&#xff09;技术正从单一语言向多语言、跨文化、情感化方向演进。当前主流TTS系统大多聚焦于中文或…

作者头像 李华
网站建设 2026/5/2 14:07:06

DIFY本地部署:快速验证AI创意的秘密武器

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个基于DIFY本地部署的快速原型工具&#xff0c;支持&#xff1a;1. 自然语言描述自动生成原型代码&#xff1b;2. 一键部署测试环境&#xff1b;3. 实时反馈和迭代优化&…

作者头像 李华