C++(14)判断map中key值是否存在

map的使用过程中会有根据map中是否存在某个键值来决定是否向里面赋值的操作,这里介绍两种方式

1.find函数

iterator find ( const key_type& key );

如果key存在,则find返回key对应的迭代器,如果key不存在,则find返回尾后迭代器 .end()。可以参考下面的示例来判断key值是否存在

if (mymap.find(key) == mymap.end())
    cout << "没有这个key" << endl;

2.count函数

count函数用于统计key值在map中出现的次数,map的key不允许重复,因此如果key存在返回1,不存在返回0

if (mymap.count(key) == 0)
    cout << "no this key" << endl;

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++ ,我们可以使用 `std::map` 容器的 `find()` 函数来判断一个 key 是否存在map 。如果 `find()` 函数返回的是 map 的 `end()` 迭代器,则说明该 key 不存在于 map 。如果存在,则返回指向该 key 的迭代器。 下面是一个示例代码,演示了如何判断 map 是否存在某个 key,如果不存在则插入该 key-value 键对: ```c++ #include <iostream> #include <map> #include <string> int main() { std::map<std::string, int> myMap; // 判断 key 是否存在 std::string key = "hello"; if (myMap.find(key) == myMap.end()) { // key 不存在,插入 key-value 键对 myMap.insert(std::make_pair(key, 1)); std::cout << "key \"" << key << "\" inserted" << std::endl; } else { // key 存在,打印对应的 value std::cout << "key \"" << key << "\" exists, value is " << myMap[key] << std::endl; } // 再次尝试插入同一个 key,不会插入,只会更新 value myMap.insert(std::make_pair(key, 2)); std::cout << "key \"" << key << "\" exists, value is " << myMap[key] << std::endl; return 0; } ``` 在上面的示例代码,我们创建了一个 `std::map` 对象 `myMap`,并尝试插入一个 key 为 `"hello"` 的键对。首先,使用 `find()` 函数判断key 是否存在map ,由于此时 map 是空的,因此 `find()` 函数返回的是 map 的 `end()` 迭代器,意味着该 key 不存在于 map 。因此,我们使用 `insert()` 函数插入了 `"hello"` 和 `1` 两个作为键对。 接着,我们再次尝试插入同一个 key,这次由于该 key 已经存在于 map ,因此 `insert()` 函数只会更新其对应的 value ,不会插入新的键对。最后,我们打印出该 key 对应的 value ,发现其已经被更新为 `2`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值