c++怎么使用map来存储键值对_c++ map容器存储键值对示例

map是C++中用于存储唯一键值对并自动排序的关联容器,定义在头文件中,支持insert、下标等方式插入,可使用范围for或迭代器遍历,推荐用find查找以避免下标访问导致的意外插入。

c++怎么使用map来存储键值对_c++ map容器存储键值对示例

在C++中,map 是一种关联容器,用于存储键值对(key-value pairs),其中每个键都唯一,并自动按照键的顺序排序。它定义在

头文件中,通常用于需要快速查找、插入和删除数据的场景。

包含头文件并声明 map

使用 map 前需要包含对应的头文件,并通过模板参数指定键和值的类型:

#include iostream>
#include

#include

using namespace std;

声明一个 map,例如存储学号(int)与姓名(string)的映射:

map studentMap;

插入键值对的几种方式

有多种方法可以向 map 中添加元素:

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

使用 insert() 方法:
studentMap.insert({101, “Alice”});
studentMap.insert(make_pair(102, “Bob”)); 使用下标操作符 []:
studentMap[103] = “Charlie”;
注意:如果键已存在,[] 会覆盖原值;若不存在,则创建新元素。

遍历 map 中的键值对

可以使用范围 for 循环配合结构化绑定(C++17 起支持)来遍历:

for (const auto& [id, name] : studentMap) {
    cout }

如果不支持 C++17,可使用迭代器:

for (auto it = studentMap.begin(); it != studentMap.end(); ++it) {
    cout first second }

查找和访问元素

使用 find() 可判断键是否存在:

auto it = studentMap.find(102);
if (it != studentMap.end()) {
    cout second } else {
    cout }

也可以直接用 [] 访问,但注意:如果键不存在,[] 会自动插入一个默认值,可能造成意外结果。

完整示例代码

#include stream>
#include

#include
using namespace std;

int main() {
    map students;

    students.insert({101, “Alice”});
    students[102] = “Bob”;
    students.insert(make_pair(103, “Charlie”));

    for (const auto& [id, name] : students) {
        cout     }

    return 0;
}

输出结果:

ID: 101, Name: Alice
ID: 102, Name: Bob
ID: 103, Name: Charlie

基本上就这些。map 自动排序、键唯一、操作高效,是处理键值映射的常用选择。注意根据需求选择插入和访问方式,避免无意中创建多余元素。

以上就是c++++怎么使用map来存储键值对_c++ map容器存储键值对示例的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1479556.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 03:53:34
下一篇 2025年12月19日 03:53:47

相关推荐

发表回复

登录后才能评论
关注微信