news 2026/6/21 16:48:21

C++ STL容器入门:三大核心用法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++ STL容器入门:三大核心用法

以下是一篇面向初学者的C++ STL容器入门教程,重点介绍三种最常用的容器及其基本操作:


C++ STL容器入门指南

STL(Standard Template Library)是C++标准库的核心组成部分,提供了高效的容器(如数组、链表、映射等)和算法。本文将通过代码示例手把手教你使用以下容器:

  1. vector(动态数组)
  2. map(键值对集合)
  3. set(唯一元素集合)

1. vector:动态数组

vector类似于普通数组,但支持自动扩容。

基本操作:

#include <vector> #include <iostream> using namespace std; int main() { // 初始化 vector<int> nums = {10, 20, 30}; // 尾部添加元素 nums.push_back(40); // {10, 20, 30, 40} // 访问元素(支持索引) cout << nums[0] << endl; // 输出:10 // 遍历 for (int i = 0; i < nums.size(); i++) { cout << nums[i] << " "; // 输出:10 20 30 40 } return 0; }

2. map:键值对集合

map以键(key)和值(value)的形式存储数据,键具有唯一性。

基本操作:

#include <map> #include <iostream> using namespace std; int main() { // 初始化 map<string, int> scores = {{"Alice", 90}, {"Bob", 85}}; // 插入新键值对 scores["Charlie"] = 88; // {"Alice":90, "Bob":85, "Charlie":88} // 查找元素 if (scores.find("Bob") != scores.end()) { cout << "Bob的分数:" << scores["Bob"] << endl; // 输出:85 } // 遍历 for (auto& pair : scores) { cout << pair.first << ": " << pair.second << endl; } return 0; }

3. set:唯一元素集合

set自动去重,并默认按升序排列元素。

基本操作:

#include <set> #include <iostream> using namespace std; int main() { // 初始化 set<int> uniqueNums = {3, 1, 2}; // 插入元素(自动去重) uniqueNums.insert(2); // 集合仍为 {1, 2, 3} // 检查元素是否存在 if (uniqueNums.count(3) > 0) { cout << "3存在!" << endl; } // 遍历(有序输出) for (int num : uniqueNums) { cout << num << " "; // 输出:1 2 3 } return 0; }

核心注意事项

  1. 越界访问vector[]操作符不检查边界,建议用.at(i)(会抛异常)。
  2. 查找效率mapset基于红黑树实现,查找时间复杂度为 $O(\log n)$。
  3. 迭代器失效:在vector中插入元素可能导致原有迭代器失效。

练习建议
尝试用vector存储学生姓名,用map关联姓名与分数,并用set记录不及格学生名单。

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

从 A2UI 到 PSUIP:AI 生成 UI 的底层革新与 “又快又好” 实践突破

在 AI 驱动界面生成的技术演进中&#xff0c;如何平衡生成效率、呈现精准度与界面质感&#xff0c;始终是行业核心命题。Google A2UI 以 JSON 为载体、扁平化邻接表为结构&#xff0c;为 AI 与 UI 的交互搭建了基础框架&#xff0c;但在信息呈现的完整性、界面逻辑的连贯性&…

作者头像 李华
网站建设 2026/5/28 22:07:35

C++11新特性全面解析

C11 新特性详解&#xff1a;可变参数模板、新的类功能、lambda 表达式与包装器 C11 引入了多项重要特性&#xff0c;显著提升了代码的灵活性、可读性和效率。本文将逐步解析可变参数模板、新的类功能、lambda 表达式和包装器&#xff08;如 std::function&#xff09;&#xf…

作者头像 李华
网站建设 2026/6/15 12:11:07

Qwen-Image-2512自动化方案:每天处理上万张图

Qwen-Image-2512自动化方案&#xff1a;每天处理上万张图 在电商主图批量更新、社交媒体内容日更、AI设计平台素材生成等高频图像生产场景中&#xff0c;团队常面临一个现实瓶颈&#xff1a;一张高质量商品图从构思到出稿平均耗时8分钟&#xff0c;而每日需求量动辄上千张。更棘…

作者头像 李华
网站建设 2026/6/10 16:02:36

小白也能懂:多模态语义评估引擎在内容审核中的应用

小白也能懂&#xff1a;多模态语义评估引擎在内容审核中的应用 你有没有遇到过这样的场景&#xff1a; 运营同学发来一张商品图&#xff0c;配文“全新未拆封iPhone 15 Pro”&#xff0c;系统却只靠OCR识别出“iPhone”就放行&#xff1b; 或者用户上传一张模糊截图&#xff0…

作者头像 李华
网站建设 2026/5/31 2:33:10

Keil5中文乱码的解决方法图解说明(Win10/Win11)

Keil5中文乱码?别再瞎试编码了——Win10/Win11下真正管用的三步闭环方案 你有没有在Keil5里写完一行注释:“// 初始化ADC通道0”,回过头一看,编辑器里只剩一串方块“□□□□□□□”? 或者调试时Watch窗口里明明定义了 char* msg = "系统启动完成"; ,结果…

作者头像 李华