C++ Multiset lower_bound() 函数用于返回一个迭代器,该迭代器指向 multiset 容器中的键,相当于传入参数中的 val。
如果 val 不存在于 multiset 容器中,则它返回一个迭代器,指向刚好大于 val 的紧邻下一个元素。
用法
iterator lower_bound (const value_type& val) const; //until C++ 11
iterator lower_bound (const value_type& val); //since C++ 11
const_iterator lower_bound (const value_type& val) const; //since C++ 11
参数
val:要在多集容器中搜索的值。
返回值
它返回一个迭代器,指向多重集容器中的值,相当于传入参数的 val。如果没有这样的元素返回 end()。
复杂度
大小为对数。
迭代器有效性
没有变化。
数据竞争
访问容器(常量和非常量版本都不会修改多集)。
同时访问容器的元素是安全的。
异常安全
如果抛出异常,则多重集中没有变化。
例子1
让我们看一个简单的例子来获取给定键的下界:
#include <iostream>
#include <set>
using namespace std;
int main(void) {
multiset<char> m = {'a','b','c','a','c'};
auto it = m.lower_bound('c');
cout << "Lower bound(=) of c is:" << *it;
return 0;
}
输出:
Lower bound(=) of c is:c
在上面的例子中,c 的下限是 c。
例子2
让我们看一个简单的例子,将 multiset 的元素从下限擦除到上限:
#include <iostream>
#include <set>
using namespace std;
int main ()
{
multiset<int> mymultiset;
multiset<int>::iterator itlow,itup;
for (int i=1; i<10; i++) mymultiset.insert(i*10); // 10 20 30 40 50 60 70 80 90
itlow=mymultiset.lower_bound (30); // ^
itup=mymultiset.upper_bound (60); // ^
mymultiset.erase(itlow,itup); // 10 20 70 80 90
std::cout << "mymultiset contains:";
for (multiset<int>::iterator it=mymultiset.begin(); it!=mymultiset.end(); ++it)
cout << ' ' << *it;
cout << '\n';
return 0;
}
输出:
mymultiset contains:10 20 70 80 90
在上面的例子中,erase() 函数将 multiset 的元素从下限(=)到上限(>)擦除并打印剩余的内容。
例子3
让我们看一个简单的例子:
#include <set>
#include <iostream>
using namespace std;
int main( )
{
using namespace std;
multiset <int> s1;
multiset <int>::const_iterator s1_AcIter, s1_RcIter;
s1.insert( 10 );
s1.insert( 20 );
s1.insert( 30 );
s1_RcIter = s1.lower_bound( 20 );
cout << "The element of multiset s1 with a key of 20 is:"
<< *s1_RcIter << "." << endl;
s1_RcIter = s1.lower_bound( 40 );
// If no match is found for the key, end( ) is returned
if ( s1_RcIter == s1.end( ) )
cout << "The multiset s1 doesn't have an element "
<< "with a key of 40." << endl;
else
cout << "The element of multiset s1 with a key of 40 is:"
<< *s1_RcIter << "." << endl;
// The element at a specific location in the multiset can be found
// by using a dereferenced iterator that addresses the location
s1_AcIter = s1.end( );
s1_AcIter--;
s1_RcIter = s1.lower_bound( *s1_AcIter );
cout << "The element of s1 with a key matching "
<< "that of the last element is:"
<< *s1_RcIter << "." << endl;
return 0;
}
输出:
The element of multiset s1 with a key of 20 is:20. The multiset s1 doesn't have an element with a key of 40. The element of s1 with a key matching that of the last element is:30.
示例 4
让我们看一个简单的例子:
#include<set>
#include<iostream>
using namespace std;
int main()
{
multiset<int> mp;
// insert elements in random order
mp.insert( 2 );
mp.insert( 1 );
mp.insert( 5 );
mp.insert( 4 );
cout<<"Elements are:\n";
for (auto it = mp.begin(); it != mp.end(); it++) {
cout << (*it)<< endl;
}
// when 2 is present
auto it = mp.lower_bound(2);
cout << "The lower bound of key 2 is ";
cout << (*it)<< endl;
// when 3 is not present
// points to next greater after 3
it = mp.lower_bound(3);
cout << "The lower bound of key 3 is ";
cout << (*it)<< endl;
// when 6 exceeds
it = mp.lower_bound(6);
cout << "The lower bound of key 6 is ";
cout << (*it);
return 0;
}
输出:
Elements are: 1 2 4 5 The lower bound of key 2 is 2 The lower bound of key 3 is 4 The lower bound of key 6 is 4
在上面的例子中,当我们试图找到一个超出容器的值的下限时,或者我们可以说多集容器中不存在的值,那么它将返回到结尾。
相关用法
- C++ Multiset get_allocator()用法及代码示例
- C++ Multiset emplace_hint()用法及代码示例
- C++ Multiset equal_range()用法及代码示例
- 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 lower_bound()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。