stl中map的四种插入方法总结

stl中map的四种插入方法总结

方法一:pair
例:
map<int, string> mp;
mp.insert(pair<int,string>(1,"aaaaa"));

方法二:make_pair
例:
map<int, string> mp;
mp.insert(make_pair<int,string>(2,"bbbbb"));

方法三:value_type
例:
map<int, string> mp;
mp.insert(map<int, string>::value_type(3,"ccccc"));

方法四:[]
例:
map<int, string> mp;
mp[4] = "ddddd";

四种方法异同:
前三种方法当出现重复键时,编译器会报错,而第四种方法,当键重复时,会覆盖掉之前的键值对。

综合测试:
#include<iostream>
#include<map>
using namespace std;

int main()
{
    map<int, string> mp;
    //map的插入方法有4种
    //insert返回值为pair   原型:typedef pair<iterator, bool> _Pairib
    //方法1.pair 	在插入重复键的情况下前三种方法类似,这里只测试第一种
    pair<map<int,string>::iterator, bool> pair1 = mp.insert(pair<int,string>(1,"aaaaa11111"));
    if (pair1.second == true)
    {
        cout<< "插入成功" <<endl;
    }
    else
    {
        cout<< "插入失败" <<endl;
    }

    pair<map<int,string>::iterator, bool> pair2 = mp.insert(pair<int,string>(1,"aaaaa22222"));
    if (pair2.second == true)
    {
        cout<< "插入成功" <<endl;
    }
    else
    {
        cout<< "插入失败" <<endl;
    }
    //方法2.make_pair
    mp.insert(make_pair<int,string>(3,"bbbbb33333"));
    mp.insert(make_pair<int,string>(4,"bbbbb44444"));

    //方法3.value_type
    mp.insert(map<int, string>::value_type(5,"ccccc55555"));
    mp.insert(map<int, string>::value_type(6,"ccccc66666"));

    //方法4.[]
    mp[7] = "ddddd77777";
    mp[7] = "ddddd88888";

    for (map<int,string>::iterator it = mp.begin(); it != mp.end(); it++)
    {
        cout<< it->first << "\t" << it->second <<endl;
    }
    cout<< "--------------------------------" <<endl;
    //删除
    while(!mp.empty())
    {
        map<int,string>::iterator it = mp.begin();
        cout<< it->first << "\t" << it->second <<endl;
        mp.erase(it);
    }

    return 0;
}





  • 6
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STL(Standard Template Library)提供了一个名为`std::map`的关联容器,它基于红黑树实现,用于存储键值对,并按照键的顺序进行排序。下面是`std::map`容器的一些常用方法: 1. 插入元素: ```cpp std::map<Key, Value> myMap; myMap.insert(std::make_pair(key, value)); // 使用insert方法插入键值对 myMap[key] = value; // 使用下标操作符[]插入键值对,如果键已存在,则会更新值 ``` 2. 删除元素: ```cpp myMap.erase(key); // 根据键删除元素 myMap.clear(); // 清空所有元素 ``` 3. 访问元素: ```cpp Value value = myMap[key]; // 使用下标操作符[]访问指定键对应的值 auto it = myMap.find(key); // 使用find方法查找指定键的迭代器 if (it != myMap.end()) { Value value = it->second; // 通过迭代器访问指定键对应的值 } ``` 4. 遍历容器: ```cpp for (const auto& pair : myMap) { Key key = pair.first; // 键 Value value = pair.second; // 值 // 其他操作 } ``` 5. 判断元素是否存在: ```cpp if (myMap.count(key) > 0) { // 键存在 } ``` 6. 获取容器大小和判断容器是否为空: ```cpp size_t size = myMap.size(); // 获取容器键值对的个数 bool isEmpty = myMap.empty(); // 判断容器是否为空 ``` 这些是`std::map`容器的一些常用方法,还有其他一些方法和成员函数可以进一步扩展其功能。你可以参考C++标准库的文档以获取更详细的信息。 希望对你有所帮助!如果还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值