C++ Multiset equal_range()函数用于返回包含容器中所有等于val的元素的范围的边界。
如果 val 不匹配容器中的任何值,则返回值范围将为长度 0,并且两个迭代器都将指向最接近的大于 val 的值。否则,如果 val 大于容器中的所有元素,则它指向 end。
用法
pair<const_iterator,const_iterator> equal_range (const value_type& val) const;
pair<iterator,iterator> equal_range (const value_type& val);
范围由两个迭代器定义,一个指向不小于值 val 的第一个元素,另一个指向大于值 val 的第一个元素。
参数
val: 要在多集容器中搜索的值。
返回值
此函数返回对。其中pair::first 位于与lower_bound (val) 将返回的值相同的范围的下限,pair::second 与upper_bound (val) 将返回的值相同,它对应的范围的上限.
复杂度
大小为对数。
迭代器有效性
没有变化。
数据竞争
访问容器(const 和 non-const 版本都不会修改容器)。
同时访问多重集的元素是安全的。
异常安全
如果抛出异常,则容器中没有变化。
例子1
让我们看一个简单的例子:
#include <iostream>
#include <set>
using namespace std;
int main(void) {
multiset<char> m = {'a','b','c','a'};
auto ret = m.equal_range('b');
cout << "Lower bound of b is:" << *ret.first<< endl;
cout << "Upper bound of b is:" << *ret.second<< endl;
return 0;
}
输出:
Lower bound of b is:b Upper bound of b is:c
在上面的例子中,b 的下限是 b,b 的上限是 c。
例子2
让我们看一个简单的例子:
#include <iostream>
#include <set>
using namespace std;
int main()
{
// initialize container
multiset<int> mp;
// insert elements in random order
mp.insert( 4 );
mp.insert( 1 );
mp.insert( 4 );
pair<multiset<int>::const_iterator,multiset<int>::const_iterator> ret;
ret = mp.equal_range(10);
cout << "The lower bound is:" << *ret.first;
cout << "\nThe upper bound is:" << *ret.second;
return 0;
}
输出:
The lower bound is 3 The upper bound is 3
在上面的例子中, equal_range() 函数返回到 end() 即 3 因为它试图找到 10 不存在于多重集 mp 因此,它返回到最后。
例子3
让我们看一个简单的例子:
#include <set>
#include <iostream>
int main( )
{
using namespace std;
typedef multiset<int, less< int > > IntMultiset;
IntMultiset s1;
multiset <int, less< int > >::const_iterator s1_RcIter;
s1.insert( 10 );
s1.insert( 20 );
s1.insert( 30 );
pair <IntMultiset::const_iterator, IntMultiset::const_iterator> p1, p2;
p1 = s1.equal_range( 20 );
cout << "The upper bound of the element with "
<< "a key of 20 in the multiset s1 is:"
<< *(p1.second) << "." << endl;
cout << "The lower bound of the element with "
<< "a key of 20 in the multiset s1 is:"
<< *(p1.first) << "." << endl;
// Compare the upper_bound called directly
s1_RcIter = s1.upper_bound( 20 );
cout << "A direct call of upper_bound( 20 ) gives "
<< *s1_RcIter << "," << endl
<< "matching the 2nd element of the pair"
<< " returned by equal_range( 20 )." << endl;
p2 = s1.equal_range( 40 );
// If no match is found for the key,
// both elements of the pair return end( )
if ( ( p2.first == s1.end( ) ) && ( p2.second == s1.end( ) ) )
cout << "The multiset s1 doesn't have an element "
<< "with a key less than 40." << endl;
else
cout << "The element of multiset s1 with a key >= 40 is:"
<< *(p1.first) << "." << endl;
return 0;
}
输出:
The upper bound of the element with a key of 20 in the multiset s1 is:30. The lower bound of the element with a key of 20 in the multiset s1 is:20. A direct call of upper_bound( 20 ) gives 30, matching the 2nd element of the pair returned by equal_range( 20 ). The multiset s1 doesn't have an element with a key less than 40.
示例 4
让我们看一个简单的例子:
#include <iostream>
#include <set>
using namespace std;
int main ()
{
std::multiset<int> mymultiset;
for (int i=1; i<=5; i++) mymultiset.insert(i*10); // mymultiset:10 20 30 40 50
pair<std::multiset<int>::const_iterator,multiset<int>::const_iterator> ret;
ret = mymultiset.equal_range(30);
cout << "the lower bound points to:" << *ret.first << '\n';
cout << "the upper bound points to:" << *ret.second << '\n';
return 0;
}
输出:
the lower bound points to:30 the upper bound points to:40
相关用法
- C++ Multiset emplace_hint()用法及代码示例
- C++ Multiset lower_bound()用法及代码示例
- C++ Multiset get_allocator()用法及代码示例
- C++ Math scalbn()用法及代码示例
- C++ Math acosh()用法及代码示例
- C++ Math asinh()用法及代码示例
- C++ Math isgreater()用法及代码示例
- C++ Math fabs()用法及代码示例
- C++ Math islessgreater()用法及代码示例
- C++ Math log2()用法及代码示例
- C++ Math nearbyint()用法及代码示例
- C++ Math tan()用法及代码示例
- C++ Math log()用法及代码示例
- C++ Math nextafter()用法及代码示例
- C++ Math fdim()用法及代码示例
- C++ Math isfinite()用法及代码示例
- C++ Math erfc()用法及代码示例
- C++ Math sinh()用法及代码示例
- C++ Math scalbln()用法及代码示例
- C++ Math cosh()用法及代码示例
注:本文由纯净天空筛选整理自 C++ Multiset equal_range()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。