在C++中,multimap中如果有一个key对应了几个value,那么怎样才能将它对应的value一一输出

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在C++中,multimap中如果有一个key对应了几个value,那么怎样才能将它对应的value一一输出相关的知识,希望对你有一定的参考价值。

例如key是是一个string 类型数据,为“中国”,对应着几个整形数据,例如50、55、60,那么当使用find函数来查找“中国”这个key的时候,怎样按行输出这几个数字?

1、定义一个数组,其中value有重复部分。

2、使用array_keys()获取键名。

3、保存文件,在浏览器查看array_keys()输出。

4、使用array_search()获取键名。

5、保存文件,在浏览器查看array_search()输出结果。

参考技术A

在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("中国"),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));
//方式1
int k;
multimap<string,int>::iterator m;
m = m_map.find(s);
for(k = 0;k != m_map.count(s);k++,m++)
cout<<m->first<<"--"<<m->second<<endl;
//方式2
multimap<string,int>::iterator beg,end;
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;

本回答被提问者采纳
参考技术B iterator lower_bound( const key_type &key );

iterator upper_bound( const key_type &key );

或者用
pair equal_range( const key_type &key );

以上是关于在C++中,multimap中如果有一个key对应了几个value,那么怎样才能将它对应的value一一输出的主要内容,如果未能解决你的问题,请参考以下文章

[C/C++] multimap查找一个key对应的多个value

如何获得multimap的中的key的数目

c++ map基础知识、按键排序、按值排序

C++ STL|深入理解关联容器multimap和map及其查找操作

STL之Map和multimap容器

C++ multimap 查找指定的元素