std::multimap<int, std::string> m;
m.insert(std::make_pair(0, "w0"));
m.insert(std::make_pair(1, "w1"));
m.insert(std::make_pair(1, "w11"));
m.insert(std::make_pair(2, "w2"));
for (std::multimap<int, std::string>::iterator it = m.begin(); it != m.end(); it++)
{
printf("%d - %s\n", it->first, it->second.c_str());
}
std::multimap<int, std::string>::iterator fit = m.find(1); //just first one that key = 1
std::pair<std::multimap<int, std::string>::iterator, std::multimap<int, std::string>::iterator> pr = m.equal_range(1); //all that key = 1
std::multimap<int, std::string>::iterator pit = pr.first;
while (pit != pr.second)
{
printf("%d - %s\n", pit->first, pit->second.c_str());
pit++;
}
原文:http://www.cnblogs.com/cleymore/p/3799360.html