在集合中插入值
插入可以使用三种不同的插入方法。
- 首先,简单插入值。此方法返回一对,允许调用者检查插入是否确实发生。
- 其次,通过提示将插入值的位置进行插入。目标是在这种情况下优化插入时间,但知道应该插入值的位置不是常见情况。在这种情况下要小心; 提供提示的方式因编译器版本而异。
- 最后,你可以通过给出开始和结束指针来插入一系列值。起始的一个将包含在插入中,结尾的一个将被排除。
#include <iostream>
#include <set>
int main ()
{
std::set<int> sut;
std::set<int>::iterator it;
std::pair<std::set<int>::iterator,bool> ret;
// Basic insert
sut.insert(7);
sut.insert(5);
sut.insert(12);
ret = sut.insert(23);
if (ret.second==true)
std::cout << "# 23 has been inserted!" << std::endl;
ret = sut.insert(23); // since it's a set and 23 is already present in it, this insert should fail
if (ret.second==false)
std::cout << "# 23 already present in set!" << std::endl;
// Insert with hint for optimization
it = sut.end();
// This case is optimized for C++11 and above
// For earlier version, point to the element preceding your insertion
sut.insert(it, 30);
// inserting a range of values
std::set<int> sut2;
sut2.insert(20);
sut2.insert(30);
sut2.insert(45);
std::set<int>::iterator itStart = sut2.begin();
std::set<int>::iterator itEnd = sut2.end();
sut.insert (itStart, itEnd); // second iterator is excluded from insertion
std::cout << std::endl << "Set under test contains:" << std::endl;
for (it = sut.begin(); it != sut.end(); ++it)
{
std::cout << *it << std::endl;
}
return 0;
}
输出将是:
# 23 has been inserted!
# 23 already present in set!
Set under test contains:
5
7
12
20
23
30
45