multimap容器

multimap容器

1、multimap和map基本相同,但是multimap允许插入重复键值的元素,由于允许重复键值的存在,所以multimap的插入删除查找与map不同。
2、元素插入可以进行键值相同的元素的插入
3、删除操作则可以删除某迭代器位置上的元素,某迭代器区间的元素和某键值的所有重复元素,可以clear()清空multimap
4、查找find(),找到则返回找到的第一个元素的迭代器位置,否则返回m.end()迭代器位置

#include<iostream>

#include<map>

#include<string>

using namespace std;

 

int main()

{

    multimap<string,double> m;

    //插入操作

    m.insert(make_pair("jack",307.5));

    m.insert(pair<string,double>("kity",200));     

    m.insert(pair<string,double>("memi",500));

    //插入相同元素

    m.insert(pair<string,double>("jack",306));

    multimap<string,double>::iterator it;

    for(it=m.begin();it!=m.end();it++)

    {

       cout<<(*it).first<<":"<<(*it).second<<endl;                                  

    }

 

    it=m.find("jack");

    if(it!=m.end()) 

    {

       cout<<"找到了:"<<(*it).first<<":"<<(*it).second<<endl;

       cout<<"当前元素个数是:"<<m.size()<<endl<<endl; 

    }

    else

    {

       cout<<"没找到jack"<<endl;

       cout<<"当前元素个数是:"<<m.size()<<endl<<endl;

    }

 

    //删除键为jack的元素

    m.erase("jack");

    cout<<"After deleting"<<endl; 

 

    for(it=m.begin();it!=m.end();it++)

    {

       cout<<(*it).first<<":"<<(*it).second<<endl;                                  

    }

    it=m.find("Jack");

    if(it!=m.end()) {cout<<(*it).first<<":"<<(*it).second<<endl; }

    else cout<<"没找到jack"<<endl;

    cout<<"当前元素个数是:"<<m.size()<<endl;

    system("pause");

    return 0;

}

 

 用法二:查找所有的同键值

#include <iostream>

#include <map>

#include <string>

using namespace std;

int main(void)

{

multimap<string,string,less<string> > mulmap;

multimap<string,string,less<string> >::iterator p; //初始化多重映射mulmap:

typedef multimap<string,string,less<string> >::value_type vt;

typedef string s;

mulmap.insert(vt(s("Tom "),s("is a student")));

mulmap.insert(vt(s("Tom "),s("is a boy")));

mulmap.insert(vt(s("Tom "),s("is a bad boy of blue!")));

mulmap.insert(vt(s("Jerry "),s("is a student")));

mulmap.insert(vt(s("Jerry "),s("is a beatutiful girl")));

mulmap.insert(vt(s("DJ "),s("is a student")));

//输出初始化以后的多重映射mulmap:

for(p=mulmap.begin();p!=mulmap.end();++p)

       cout<<(*p).first<<(*p).second<<endl; //检索并输出Jerry键所对应的所有的值

cout<<"find Jerry :"<<endl;

p=mulmap.find(s("Jerry "));

while((*p).first=="Jerry ")

{

   cout<<(*p).first<<(*p).second<<endl;

   ++p;

}

cin.get();

return 0;

}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

nokianasty

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值