0

0

c++ map如何遍历和查找元素_c++中map容器常用操作与使用技巧

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-11-10 13:47:03

|

739人浏览过

|

来源于php中文网

原创

C++中map是基于红黑树的关联容器,支持O(log n)时间复杂度的查找、插入和删除。1. 遍历方式包括迭代器、范围for循环(推荐使用const auto&)和C++17结构化绑定;2. 查找方法有find()(返回迭代器)、count()(判断存在性)、at()(越界抛异常)和operator[](不存在时插入默认值,慎用于只读场景);3. 常用操作:insert/emplace插入元素,erase删除元素,empty/size判断状态,支持自定义比较器(如std::greater)实现降序或复杂类型排序;4. 遍历时删除需用erase返回的迭代器避免失效问题。熟练掌握这些技巧可提升代码效率与安全性。

c++ map如何遍历和查找元素_c++中map容器常用操作与使用技巧

在C++中,map 是一个非常常用的关联容器,用于存储键值对(key-value pairs),并自动根据键进行排序。它基于红黑树实现,查找、插入和删除的时间复杂度为 O(log n)。下面介绍 map 的遍历、查找以及一些常用操作和技巧。

如何遍历 map

遍历 map 有多种方式,最常见的是使用迭代器和范围 for 循环(C++11 起支持)。

1. 使用迭代器遍历:

#include 
#include 

std::map myMap = {{1, "Alice"}, {2, "Bob"}, {3, "Charlie"}};

for (auto it = myMap.begin(); it != myMap.end(); ++it) {
    std::cout << "Key: " << it->first 
              << ", Value: " << it->second << std::endl;
}

2. 使用范围 for 循环(推荐):

立即学习C++免费学习笔记(深入)”;

for (const auto& pair : myMap) {
    std::cout << "Key: " << pair.first 
              << ", Value: " << pair.second << std::endl;
}

如果不想修改值,建议使用 const auto& 避免拷贝,提升性能。

3. 使用结构化绑定(C++17):

for (const auto& [key, value] : myMap) {
    std::cout << "Key: " << key << ", Value: " << value << std::endl;
}

语法更简洁,可读性更强。

如何查找元素

map 提供了多种查找方法,适用于不同场景。

1. find() 方法:

返回指向元素的迭代器,若未找到则返回 end()。适合需要判断是否存在并获取值的情况。

auto it = myMap.find(2);
if (it != myMap.end()) {
    std::cout << "Found: " << it->second << std::endl;
} else {
    std::cout << "Not found" << std::endl;
}

2. count() 方法:

返回键出现的次数(map 中最多为 1)。适合只关心是否存在的情况。

if (myMap.count(2)) {
    std::cout << "Key 2 exists" << std::endl;
}

3. at() 方法:

SEEK.ai
SEEK.ai

AI驱动的智能数据解决方案,询问您的任何数据并立即获得答案

下载

通过键访问值,若键不存在会抛出 std::out_of_range 异常。适合确定键一定存在时使用。

try {
    std::cout << myMap.at(1) << std::endl;
} catch (const std::out_of_range& e) {
    std::cout << "Key not found!" << std::endl;
}

4. operator[]:

如果键不存在,会自动插入一个默认构造的值。注意:这可能改变 map 内容。

std::cout << myMap[1]; // 安全
std::cout << myMap[999]; // 若999不存在,会插入 {999, ""}

因此,仅用于查找时不推荐使用 [],除非你确实想插入默认值。

常用操作与技巧

掌握这些技巧能让你更高效地使用 map。

1. 插入元素:

  • myMap.insert({key, value}); —— 推荐方式,避免重复插入
  • myMap[key] = value; —— 若已存在会覆盖
  • myMap.emplace(key, value); —— 原地构造,效率更高

2. 删除元素:

  • myMap.erase(key); —— 按键删除
  • myMap.erase(it); —— 按迭代器删除

3. 判断是否为空或获取大小:

  • myMap.empty() —— 返回 true 表示为空
  • myMap.size() —— 返回元素个数

4. 自定义比较函数:

例如按降序排列

std::map> descMap;

5. 处理多关键字或复杂类型:

map 支持自定义类型作为 key,前提是提供可比较的 operator

6. 遍历时删除元素:

必须小心使用迭代器失效问题:

for (auto it = myMap.begin(); it != myMap.end();) {
    if (shouldRemove(it->first)) {
        it = myMap.erase(it); // erase 返回下一个有效迭代器
    } else {
        ++it;
    }
}
基本上就这些。熟练掌握 map 的遍历、查找和常用技巧,能显著提升代码效率和可读性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2023.11.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

531

2023.09.20

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

61

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.27

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

18

2026.01.29

clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

12

2026.01.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

8

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号