在multimap中使用find

转载自百度知道,由龍__鳳提供的解决方法。

原文链接:http://zhidao.baidu.com/link?url=7XaoxjVcQ7BMWUWXkawocTPM76rYVtO4fsbu8Lzl51O2Cqx0q9XuaAW6IlNmXM7Nu8X-viE0Eta9QCQOTHPUZtZ5hzv3okIfdiuACKuEBGa

本文链接:http://blog.youkuaiyun.com/wlsgzl/article/details/41697877

===================================================

本文仅对部分代码做了调整。

===================================================

在multimap中,同一个键关联的元素必然相邻存放。基于这个事实,就可以将某个键对应的值一一输出。

1、使用find和count函数。count函数求出某个键出现的次数,find函数返回一个迭代器,指向第一个拥有正在查找的键的实例。

2、使用lower_bound(key)和upper_bound(key)

      lower_bound(key)返回一个迭代器,指向键不小于k的第一个元素

      upper_bound(key)返回一个迭代器,指向键不大于k的第一个元素

3、使用equat_range(key)

      返回一个迭代器的pair对象,first成员等价于lower_bound(key),second成员等价于upper_bound(key)

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

using namespace std;


int main()
{
	multimap<string,int> m_map;

	string s("中国");
	string s1("美国");

	m_map.insert(make_pair(s,50));
	m_map.insert(make_pair(s,55));
	m_map.insert(make_pair(s,60));
	m_map.insert(make_pair(s1,30));
	m_map.insert(make_pair(s1,20));
	m_map.insert(make_pair(s1,10));

	multimap<string,int>::iterator m;
	multimap<string,int>::iterator beg,end;	
	
	//方式1
	m = m_map.find(s);

	for(int k = 0;k != m_map.count(s);k++,m++)
		cout<<m->first<<"--"<<m->second<<endl;


	//方式2
	beg = m_map.lower_bound(s1);
	end = m_map.upper_bound(s1);

	for(m = beg;m != end;m++)
		cout<<m->first<<"--"<<m->second<<endl;


	//方式3
	beg = m_map.equal_range(s).first;
	end = m_map.equal_range(s).second;

	for(m = beg;m != end;m++)
		cout<<m->first<<"--"<<m->second<<endl;

	return 0;
}



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值