multimap使用lower_bound、 upper_bound、 equal_range进行特定key的遍历

/**
 * multimap 操作lower_bound、 upper_bound、 equal_range
 */


#include <map>
#include <iostream>
#include <string>


using namespace std;


int main()
{
    //定义 multimap 对象 author
    multimap<string, string> author; //第一个string 表示作者,第二个string 表示作者所著书名


    //添加作者author1 写的3本书 book11~book13 ,3种添加方式
    author.insert(
            multimap<string, string>::value_type(string("author1"),
                    string("book11")));
    author.insert(multimap<string, string>::value_type("author1", "book12"));
    author.insert(make_pair(string("author1"), string("book13")));


    //添加作者author2 写的2本书 book21~book22
    author.insert(multimap<string, string>::value_type("author2", "book21"));
    author.insert(make_pair(string("author2"), string("book22")));


    //给出author 的键author1,查找此键关联的所有值
    string search_item("author1");


    //multimap_size 表示 作者著书 数量
    multimap<string, string>::size_type multimap_size;


    //返回 search_item 的记录数,如果不存在返回0
    multimap_size = author.count(search_item);
    cout << "multimap_size : " << multimap_size << "\n";


    //定义迭代器 it ,
    multimap<string, string>::iterator it;


    //用 find 查找
    it = author.find(search_item); //如果存在指针指向键关联的第一个值
    multimap<string, string>::size_type st;
    //it、multimap_size 配合使用,操作键关联的所有值
    for (st = 0; st != multimap_size; st++, it++)
        cout << it->first << "  " << it->second << "\n";


    //用 lower_bound,upper_bound 操作键关联的值
    cout << "use lower_bound and upper_bound function :\n";
    //如果 author 中存在键search_item ,begin指向第一个匹配的元素
    multimap<string, string>::iterator begin = author.lower_bound(search_item);
    //如果 author 中存在键search_item ,end指向最后一个匹配的元素的下一位置
    multimap<string, string>::iterator end = author.upper_bound(search_item);
    while (begin != end)
    {
        cout << begin->first << " " << begin->second << "\n";
        begin++;
    }


    //用 equal_range 操作键关联的值
    cout << "use equal_range function : \n";
    //定义pair 对象position; pair数据类型是 2个 multimap<string,string>::iterator 指针。
    pair<multimap<string, string>::iterator, multimap<string, string>::iterator> position;
    //如果键存在,函数返回2个指针,第一个指针指向键第一个匹配的元素
    //第二个指针指向键最后一个匹配的元素的下一位置
    position = author.equal_range(search_item);
    while (position.first != position.second)
    {
        cout << position.first->first << "  " << position.first->second << "\n";
        position.first++;
    }
    cout << endl;


    return 0;

}


// 输出

multimap_size : 3
author1  book11
author1  book12
author1  book13
use lower_bound and upper_bound function :
author1 book11
author1 book12
author1 book13
use equal_range function : 
author1  book11
author1  book12
author1  book13


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值