当前位置: 首页 > news >正文

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);

http://www.jsqmd.com/news/219826/

相关文章:

  • AGENTS.md终极指南:60,000+项目的AI协作革命
  • 告别频道混乱:一站式直播源管理解决方案
  • ENScan_GO 企业信息收集完整指南
  • NumPy版本升级效率对比:手动修复 vs AI自动化
  • CRNN OCR在合同管理中的智能应用案例
  • 内存占用多少?实测峰值800MB,适合4GB以上机器运行
  • PlotNeuralNet:告别手绘时代,代码驱动专业神经网络可视化
  • 实战:用RPGVXACE制作RTP独立运行游戏教程
  • 五分钟奇迹:用Llama Factory快速克隆你的语音对话风格
  • INA226在智能电池管理系统中的实战应用
  • ElevenClock终极指南:彻底释放Windows 11任务栏时钟的潜力
  • Go语言TOML解析终极指南:快速上手BurntSushi/toml
  • WeKnora API终极指南:从零掌握语义检索与智能问答核心技术
  • 流放之路2物品过滤系统深度解析:NeverSink过滤器完全配置手册
  • 企业级案例:ORA-12514故障的排查与解决全记录
  • 3分钟完成PostgreSQL安装:传统vs容器化效率对比
  • Spring Authorization Server实战指南:构建企业级安全认证体系的10个关键步骤
  • 2026年AI语音新趋势:开源多情感TTS+WebUI成中小企业标配
  • ProxyCat终极指南:多协议隧道代理池完整安装使用教程
  • 用Cursor快速验证你的创意:原型开发指南
  • 收藏!从裸辞到顺利入职AI大模型:我的4个月转行全记录(小白/程序员入门参考)
  • OCR预处理技巧:提升CRNN识别准确率的关键
  • 助睿BI:从数据接入到决策支撑,一站式搞定
  • 【2026年最新版】全网最详细的网络安全学习路线徒,自学网络安全的三个必经阶段!
  • Apache Griffin数据质量管理的5个高效技巧
  • 快速构建基于WinBtrfs的存储解决方案原型
  • CRNN OCR在财务报表趋势图数据提取中的实践
  • MPC-QT视频播放器(基于Qt框架播放器)
  • 【必藏】2026年AI大模型发展路线图:从技术突破到商业应用的全面解析
  • 多任务学习:CRNN的文本检测与识别