C++ map使用详细版

经过几个小时的学习以及测试,map的基本结构是熟悉,但是要想达到灵活运用恐怕还需要进一步练习。以后在涉及到C++中的哈希表时候,用map做代替.

可以横向对比一下vector,大同小异。

1 定义:键值一一对应,key不能重复

#inlcude<map> #include<string>

using namespace std;

map<sting,string> mapstring;

 

2 插入:两种形式:1)insert 2) 数组形式插入

mapstring.insert(pair<string,string>("a","b")) // pair<string,string> 必不可少,并且里面的两个类型要与定义一致

mapstring["c"]="d";

3 查找:

          1)find() 查找并且找出value 2)count() 确定key是否存在,存在返回1,不存在返回0

1)find形式:比较麻烦,需要借助迭代器

//定义迭代器 map<string,string>::iterator iter;

iter=mapstring.find("a")

if(iter!=mapstring.end()) //用这种方式迭代器迭代不到最后,说明键值是存在的

cout<<iter->first<<endl; //iter->first 这指的是key iter->value 指的是value

else

cout<<cant not find this key<<endl;

2) mapstring.count(key) //这种情况下直接用就可以了

4 删除

iter =mapstring.find(key); // 即使key不存在也不会报错,因为有if进行判断,存在才删除

if(iter!=mapstring.end()) //这里的iter迭代器和上面一样的,定义是一样的。

mapstring.erase(iter);

5 打印

for(iter=mapstring.begin();iter!=mapstring.end;iter++) //迭代打印

cout<<iter->first<<"="<<iter->second<<" ";

 

 

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
map容器是C++ STL中的关联容器之一,它提供了基于值对的映射关系(key-value)存储数据的功能。以下是关于map容器的详细使用说明: 1. 引入头文件 ```c++ #include <map> ``` 2. 定义map容器 ```c++ std::map<Key, Value> myMap; ``` 其中,Key表示的类型,Value表示值的类型。例如,如果想存储字符串类型的,整数类型的值,可以这样定义: ```c++ std::map<std::string, int> myMap; ``` 3. 插入元素 可以使用insert函数或[]运算符插入元素: ```c++ // 使用insert函数插入元素 myMap.insert(std::make_pair("apple", 1)); // 使用[]运算符插入元素 myMap["orange"] = 2; ``` 注意,如果使用[]运算符插入元素,如果不存在,则会创建一个新的值对;如果已经存在,则会覆盖原有的值。 4. 删除元素 可以使用erase函数删除指定的元素: ```c++ myMap.erase("apple"); ``` 5. 访问元素 可以使用find函数查找指定的元素,如果找到了,则返回所对应的迭代器;如果没找到,则返回end迭代器: ```c++ auto it = myMap.find("orange"); if (it != myMap.end()) { std::cout << it->first << ": " << it->second << std::endl; } ``` 可以使用[]运算符访问所对应的值: ```c++ std::cout << myMap["orange"] << std::endl; ``` 注意,如果访问不存在的,则会创建一个新的,并将其值初始化为类型的默认值。 6. 遍历元素 可以使用迭代器遍历map容器中的元素: ```c++ for (auto it = myMap.begin(); it != myMap.end(); ++it) { std::cout << it->first << ": " << it->second << std::endl; } ``` 7. 判断元素是否存在 可以使用count函数判断指定的元素是否存在,如果存在,则返回1;如果不存在,则返回0: ```c++ if (myMap.count("orange") > 0) { std::cout << "orange exists" << std::endl; } ``` 以上就是关于map容器的详细使用说明。需要注意的是,在处理大量数据时,map容器的效率可能会比较低,因为map容器是基于红黑树实现的,插入、查找、删除等操作的时间复杂度是O(logn)。如果需要处理大量数据,并且对时间性能有很高的要求,可以考虑使用unordered_map容器,它是基于哈希表实现的,插入、查找、删除等操作的时间复杂度是O(1)。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值