news 2026/6/9 22:24:24

6.STL 容器常用操作速查表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
6.STL 容器常用操作速查表

STL容器常用操作速查表

操作类型

std::vector(动态数组)

std::string(字符串)

std::map<K,V>(有序键值对)

头文件

#include <vector>

#include <string>

#include <map>

创建容器

std::vector<int> vec;(空容器)
std::vector<int> vec{1,2,3};(初始化)

std::string str;(空字符串)
std::string str = "hello";(初始化)

std::map<int, std::string> mp;(空容器)
std::map<int, std::string> mp{{1,"a"},{2,"b"}};(初始化)

添加元素

1. 尾部添加:vec.push_back(10);
2. 指定位置插入:vec.insert(vec.begin()+1, 20);(在第2位插20)

1. 拼接:str += " world";
2. 插入字符:str.insert(2, "xx");(在第3位插xx)
3. 追加字符:str.push_back('!');

1. 直接赋值:mp[101] = "张三";
2. 插入键值对:mp.insert({102, "李四"});(不覆盖已有键)

访问元素

1. 下标访问:vec[0](无越界检查)
2. 安全访问:vec.at(0)(有越界检查)
3. 首尾元素:vec.front()/vec.back()

1. 下标访问:str[0]
2. 安全访问:str.at(0)
3. 首尾字符:str.front()/str.back()

1. 下标访问:mp[101](无键则创建默认值)
2. 查找访问:auto it = mp.find(101); if(it != mp.end()) { it->second; }(推荐,无键不创建)

修改元素

vec[0] = 99;(直接赋值)

str[0] = 'H';(修改字符)
str.replace(0, 2, "HE");(替换子串)

mp[101] = "张三丰";(覆盖已有值)

删除元素

1. 尾部删除:vec.pop_back();
2. 指定位置删除:vec.erase(vec.begin()+1);
3. 清空:vec.clear();

1. 尾部删除:str.pop_back();
2. 删除子串:str.erase(1, 2);(从第2位删2个字符)
3. 清空:str.clear();

1. 按键删除:mp.erase(101);
2. 清空:mp.clear();

获取长度

vec.size()(元素个数)
vec.empty()(是否为空)

str.size()/str.length()(字符数)
str.empty()(是否为空)

mp.size()(键值对个数)
mp.empty()(是否为空)

遍历元素

// 方式1:范围for
for (int num : vec) { ... }
// 方式2:迭代器
for (auto it = vec.begin(); it != vec.end(); ++it) { *it; }

// 范围for
for (char c : str) { ... }
// 迭代器
for (auto it = str.begin(); it != str.end(); ++it) { *it; }

// 范围for(pair.first=键,pair.second=值)
for (auto& pair : mp) { pair.first; pair.second; }
// 迭代器
for (auto it = mp.begin(); it != mp.end(); ++it) { it->first; it->second; }

查找元素

// 需包含
auto it = std::find(vec.begin(), vec.end(), 10);
if (it != vec.end()) { 找到元素 }

// 查找子串位置
size_t pos = str.find("llo");
if (pos != std::string::npos) { 找到子串 }

// 按键查找(核心方式)
auto it = mp.find(101);
if (it != mp.end()) { 找到键值对 }

关键补充说明

  1. 迭代器通用规则:所有STL容器的迭代器都遵循begin()(起始位置)、end()(末尾下一位)规则,end()不指向有效元素,仅作为结束标记;
  2. map的特殊点mp[key]是“读写一体”,读取不存在的键会自动插入该键并赋值默认值(如string为空、int为0),因此只读时优先用find()
  3. 空容器判断:所有容器都可用empty()判断是否为空,比size() == 0更高效;
  4. Qt容器适配:Qt的QVector/QString/QMap操作和上表几乎一致,仅需替换:
    • 头文件:<QVector>/<QString>/<QMap>
    • 输出:用qDebug()替代cout,如qDebug() << vec[0];
    • 特有添加方式:vec << 1 << 2;(Qt容器支持)

总结

  1. 核心操作(创建、添加、访问、遍历、清空)在不同容器中逻辑统一,仅语法细节有差异;
  2. vector/string侧重“有序列表操作”,map侧重“键值对的键查找/删除”;
  3. 遍历优先用范围for(简洁),需要精准控制位置时用迭代器
  4. 查找操作中,string用find()、map用find()、vector需配合<algorithm>std::find()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 23:50:51

2026网络安全学习攻略:从入门到专家之路

&#x1f4c5; 网络安全分阶段学习路线图为了让你更直观地把握学习旅程&#xff0c;下面这张路线图汇总了从零基础到专业水平的四个关键阶段、主要学习内容和目标岗位。flowchart TDA[阶段一&#xff1a;基础入门<br>1-3个月] --> B[阶段二&#xff1a;专项深化<br…

作者头像 李华
网站建设 2026/6/10 13:11:34

USB协议基础与libusb结合学习:图解说明

深入USB通信&#xff1a;从协议原理到libusb实战开发 你有没有遇到过这样的场景&#xff1f;手头有一个定制的USB传感器&#xff0c;但系统没有现成驱动&#xff1b;或者想给一个“哑设备”做固件升级&#xff0c;却发现官方工具不够灵活。这时候&#xff0c;高级API束手无策&…

作者头像 李华
网站建设 2026/6/10 13:13:44

Open-AutoGLM官方资源泄露?深度解析真实下载来源(仅限本周开放)

第一章&#xff1a;Open-AutoGLM官方资源泄露&#xff1f;真相与风险警示 近期&#xff0c;互联网上流传一份名为“Open-AutoGLM”的开源项目资源包&#xff0c;声称包含该模型的完整训练代码、权重文件及内部文档。经多方核实&#xff0c;该项目目前并未由任何官方团队正式发布…

作者头像 李华
网站建设 2026/6/9 22:05:29

Open-AutoGLM本地部署最低硬件要求曝光:3步判断你的设备能否跑通

第一章&#xff1a;Open-AutoGLM本地部署最低硬件要求曝光&#xff1a;3步判断你的设备能否跑通部署 Open-AutoGLM 前&#xff0c;明确设备是否满足最低硬件要求至关重要。以下三步可快速判断你的系统是否具备运行条件。检查GPU显存容量 Open-AutoGLM 推理依赖至少 8GB 显存的 …

作者头像 李华
网站建设 2026/6/10 13:20:59

Java springboot基于微信小程序的宠物领养宠物用品商城系统(源码+文档+运行视频+讲解视频)

文章目录 系列文章目录目的前言一、详细视频演示二、项目部分实现截图三、技术栈 后端框架springboot前端框架vue持久层框架MyBaitsPlus微信小程序介绍系统测试 四、代码参考 源码获取 目的 摘要&#xff1a;本文设计并实现了一个基于Java Spring Boot框架与微信小程序的宠物…

作者头像 李华
网站建设 2026/6/10 13:13:41

想摆脱闭源模型束缚?Open-AutoGLM自托管方案来了,私有化部署全攻略

第一章&#xff1a;Open-AutoGLM自托管方案概述Open-AutoGLM 是一个开源的大语言模型推理框架&#xff0c;专为本地化部署和私有化运行设计。该方案支持在企业内网或个人服务器上完成模型的加载、推理与管理&#xff0c;兼顾性能与数据隐私保护。用户可通过自定义配置实现多硬件…

作者头像 李华