multiMap遍历方法

multimap是map升级版,仍然是key-value,但这个key允许重复




代码来源:http://www.cnblogs.com/dongsheng/archive/2013/09/10/3311594.html

/*
    multimap中的三种遍历方法
    multimap中如果没有查找到相应元素,则返回的迭代器是依据该元素的排列顺序该键应该插入的位置
    如果找不到,则方法一和方法二返回的两个迭代器应该相等
*/
#include <iostream>
#include <map>
#include <string>
#include <utility>

using namespace std;

int main()
{
    multimap<string, string> mulMap;
    mulMap.insert(make_pair("鲁迅", "朝花夕拾"));
    mulMap.insert(make_pair("鲁迅", "阿Q正传"));
    mulMap.insert(make_pair("鲁迅", "野草"));
    mulMap.insert(make_pair("罗贯中", "三国演义"));
    mulMap.insert(make_pair("罗贯中", "隋唐志传"));
    mulMap.insert(make_pair("琼瑶", "还珠格格"));
    mulMap.insert(make_pair("琼瑶", "情深深雨蒙蒙"));
    typedef multimap<string, string>::iterator multiMapItor;
    //方法一:推荐
    
    string author("鲁迅");
    cout << author << "的书籍有:" << endl;
    pair<multiMapItor, multiMapItor> pos = mulMap.equal_range(author);
    while(pos.first != pos.second)
    {
        cout << pos.first->second << endl;
        ++pos.first;
    }
    cout << endl;
    //方法二:
    author.assign("罗贯中");
    cout << author << "的书籍有:" << endl;
    multiMapItor beg = mulMap.lower_bound(author);
    multiMapItor end = mulMap.upper_bound(author);
    while(beg != end)
    {
        cout << beg->second << endl;
        ++beg;
    }
    cout << endl;
    //方法三:不推荐
    author.assign("琼瑶");
    cout << author << "的书籍有:" << endl;
    typedef multimap<string, string>::size_type sz_type;
    sz_type entries = mulMap.count(author);
    multiMapItor itor = mulMap.find(author);
    for(sz_type cnt = 0; cnt != entries; ++cnt)
        cout << (itor++)->second << endl;

    system("pause");
    return 0;
}


  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值