C++中遍歷multimap
阿新 • • 發佈:2018-12-29
在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,作者:龍__鳳