解决multimap中key对应了多个value,那么怎样才能将它对应的value一一输出

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

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

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

      lower_bound(key)返回一个迭代器,指向键为key的第一个元素

      upper_bound(key)返回一个迭代器,指向键为key的最后一个元素 的下一个位置

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

#include 
#include 
#include 
using namespace std;
int main()
{
    multimap 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::iterator m;
    m = m_map.find(s);
    for (k = 0; k != m_map.count(s); k++, m++)
        cout << m->first << "--" << m->second << endl;
    /*输出:
        中国--50
        中国--55
        中国--60
    */

    //方式2
    multimap::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;
    /*输出:
        美国--30
        美国--20    
        美国--10
    */

    //方式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;
    /*输出:
        中国--50
        中国--55
        中国--60
    */
    system("pause");
    return 0;
}

整理于百度百科:https://zhidao.baidu.com/question/918049459459983899.html

你可能感兴趣的:(C/C++,multimap)