341_C++_使用C++中的std::map容器查找键的时候,注意给个默认值,防止成员函数value()未查找到键,确保即使键不存在,你也能安全地获取一个值

124 篇文章 6 订阅

在C++中,std::map是一个关联容器,它存储的元素都是键值对(key-value pairs),并且按键(key)自动排序。

std::map有一个成员函数value(),它用于返回与给定键相关联的值。如果该键在map中不存在,则value()函数返回提供的默认值。

map<int, int> mKeyMaps;
int key = mKeyMaps.value(type, 0);

这里,mKeyMaps是一个int到int的映射。mKe

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
std::mapC++ 标准库的关联容器,它提供了一种对的映射关系,并且会按照的字典序自动排序。可以使用容器实现字典、统计词频等功能。 使用 std::map 需要包含头文件 <map>,其定义了该容器的类模板。定义一个 std::map 可以使用以下语法: ```c++ std::map<Key, Value> map_name; ``` 其,Key 和 Value 分别指定了的类型。例如,定义一个为字符串,为整数的 std::map 可以使用以下语句: ```c++ std::map<std::string, int> word_count; ``` 使用 std::map 插入元素可以使用 insert() 函数,删除元素可以使用 erase() 函数。查询元素可以使用 [] 运算符或者 find() 函数。例如,插入一个对可以使用以下语句: ```c++ word_count.insert(std::pair<std::string, int>("hello", 1)); ``` 使用 [] 运算符可以直接访问一个对应的,例如: ```c++ int count = word_count["hello"]; ``` 如果不存在,则会自动插入一个新的对,默认值使用 find() 函数可以查找一个对应的迭代器,例如: ```c++ std::map<std::string, int>::iterator it = word_count.find("hello"); if (it != word_count.end()) { int count = it->second; } ``` 以上就是 std::map 的基本用法。需要注意的是,std::map 内部实现使用红黑树,插入、删除、查询的时间复杂度都是 O(log n),但是相比于 std::unordered_mapstd::map 具有自动排序的特性,因此更适合于需要按照的顺序访问元素的场合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

扳手的海角

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值