public member function
<map>

std::multimap::lower_bound

      iterator lower_bound (const key_type& k);const_iterator lower_bound (const key_type& k) const;
Return iterator to lower bound
返回一个迭代器,指向容器中第一个键值不小于k的元素(即,等于k或大于k)。

该函数使用其内部的比较对象key_comp)来确定这一点,返回第一个使得key_comp(element_key,k)返回false.

的元素的迭代器。如果multimap类使用默认比较类型(less)进行实例化,则该函数返回第一个键值不小于k的元素的迭代器。

一个类似的成员函数,upper_bound,其行为与lower_bound相同,只是在multimap包含键值与k相等的元素时:在这种情况下,lower_bound返回指向这些元素中第一个元素的迭代器,而upper_bound返回指向最后一个元素之后那个元素的迭代器。

参数

k
要搜索的键。
成员类型key_type是容器中元素的类型,在map中定义为其第一个模板参数().

返回值

指向容器中第一个键值不小于k的元素的迭代器,如果所有键值都小于k,则返回multimap::end

如果multimap对象是const限定的,则该函数返回一个const_iterator。否则,它返回一个iterator.

成员类型iteratorconst_iterator是指向元素的(类型为value_type).
请注意,value_typemultimap容器中的pair<const key_type, mapped_type>.

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
// multimap::lower_bound/upper_bound
#include <iostream>
#include <map>

int main ()
{
  std::multimap<char,int> mymultimap;
  std::multimap<char,int>::iterator it,itlow,itup;

  mymultimap.insert(std::make_pair('a',10));
  mymultimap.insert(std::make_pair('b',121));
  mymultimap.insert(std::make_pair('c',1001));
  mymultimap.insert(std::make_pair('c',2002));
  mymultimap.insert(std::make_pair('d',11011));
  mymultimap.insert(std::make_pair('e',44));

  itlow = mymultimap.lower_bound ('b');  // itlow points to b
  itup = mymultimap.upper_bound ('d');   // itup points to e (not d)

  // print range [itlow,itup):
  for (it=itlow; it!=itup; ++it)
    std::cout << (*it).first << " => " << (*it).second << '\n';

  return 0;
}

b => 121
c => 1001
c => 2002
d => 11011


复杂度

相对于size对数复杂度。

迭代器有效性

没有变化。

数据竞争

访问容器(const 和非 const 版本都不会修改容器)。
不访问映射值:并发访问或修改元素是安全的。

异常安全

强保证:如果抛出异常,容器没有发生变化。

另见