首页 > 后端开发 > C++ > 正文

C++如何使用map(映射)?(入门教程)

穿越時空
发布: 2025-12-17 13:11:02
原创
191人浏览过
C++中map是基于红黑树的有序关联容器,按键升序存储键值对,支持O(log n)查找/插入/删除;需#include ,声明为std::map,常用[]、insert、emplace插入,find安全访问,范围for遍历。

c++如何使用map(映射)?(入门教程)

在C++中,map 是一种关联容器,用来存储“键-值”对(key-value pairs),并自动按键(key)升序排序。它底层基于红黑树实现,查找、插入、删除的时间复杂度都是 O(log n),适合需要有序、快速查找的场景。

如何声明和初始化 map

使用前需包含头文件:#include <map></map>,并通常配合 std:: 命名空间。

  • 基本声明:`std::map myMap;`
  • 常用组合:`std::map<:string int> scores;` —— 用姓名(字符串)查分数(整数)
  • 初始化方式:
    • 空构造:`std::map m;`
    • 列表初始化(C++11起):`std::map m = {{'a', 1}, {'b', 2}};`
    • 拷贝构造:`std::map m2 = m1;`

插入和访问元素

插入有多种写法,效果类似但行为略有不同;访问时注意避免意外创建元素。

  • m[key] = value;:若 key 不存在,会自动插入一个默认值(如 int 为 0,string 为空串),再赋值。慎用于只读查询
  • m.insert({key, value});m.insert(std::make_pair(key, value));:只插入,不覆盖已有 key
  • m.emplace(key, value);:原地构造,更高效(推荐用于大量插入)
  • 安全访问建议用 find()
    auto it = m.find("Alice");<br>if (it != m.end()) {<br>  std::cout << it->second; // 输出值<br>}
    登录后复制

遍历和修改 map

因为 map 有序,遍历时 key 自动从小到大(或按自定义比较规则)排列

Python v2.4 中文手册 chm
Python v2.4 中文手册 chm

Python v2.4版chm格式的中文手册,内容丰富全面,不但是一本手册,你完全可以把她作为一本Python的入门教程,教你如何使用Python解释器、流程控制、数据结构、模板、输入和输出、错误和异常、类和标准库详解等方面的知识技巧。同时后附的手册可以方便你的查询。

Python v2.4 中文手册 chm 2
查看详情 Python v2.4 中文手册 chm

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

  • 范围 for 循环(推荐):
    for (const auto& pair : m) {<br>  std::cout << pair.first << " => " << pair.second << "\n";<br>}
    登录后复制
  • 迭代器遍历(支持修改值):
    for (auto it = m.begin(); it != m.end(); ++it) {<br>  it->second *= 2; // 修改值,不能改 key<br>}
    登录后复制
  • 注意:不能在遍历时用 []insert 改变容器大小(可能使迭代器失效)

其他实用操作

掌握这些能更好应对实际需求:

  • m.size():返回元素个数;m.empty():判断是否为空
  • m.clear():清空所有元素
  • m.erase(key):按 key 删除;m.erase(it):按迭代器删除
  • 自定义比较函数(让 map 按降序排列):
    std::map<int, std::string, std::greater<int>> m;<br>// 或传入 lambda(C++20 起更灵活)
    登录后复制
  • 如果不需要排序,且追求更快平均性能(O(1)),可考虑 std::unordered_map

基本上就这些。map 不复杂但容易忽略细节,比如 [] 的副作用、迭代器有效性、以及 key 类型必须支持比较(默认是 )。写小例子多练几次,很快就能上手。

以上就是C++如何使用map(映射)?(入门教程)的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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