1. 程式人生 > >C++中遍歷multimap

C++中遍歷multimap

在multimap中,同一個鍵關聯的元素必然相鄰存放。基於這個事實,就可以將某個鍵對應的值一一輸出。

1、使用find和count函式count函式求出某個鍵出現的次數,find函式返回一個迭代器,指向第一個擁有正在查詢的鍵的例項。

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

      lower_bound(key)返回一個迭代器,指向鍵不小於k的第一個元素

      upper_bound(key)返回一個迭代器,指向鍵大於k的第一個元素

       就相當於通常情況下遍歷容器時的begin和end一樣。

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;
}

轉載自:https://zhidao.baidu.com/question/918049459459983899.html,作者:龍__鳳