C++中的set
是一個關聯容器,它包含一組唯一的元素。這些元素在插入時自動按鍵值進行排序。以下是一些關于C++ set
集合插入操作的技巧:
insert()
函數插入元素:std::set<int> mySet;
mySet.insert(5);
mySet.insert(10);
std::set<int> mySet;
std::vector<int> vec = {1, 2, 3, 4, 5};
mySet.insert(vec.begin(), vec.end());
emplace()
函數直接構造元素:std::set<std::pair<int, std::string>> mySet;
mySet.emplace(std::make_pair(1, "one"));
mySet.emplace(2, "two"); // 從C++17開始支持
std::set<int> mySet;
auto result = mySet.insert(5);
if (result.second) {
std::cout << "Element inserted successfully."<< std::endl;
} else {
std::cout << "Element already exists in the set."<< std::endl;
}
hint
參數提高插入性能(僅適用于有序容器):std::set<int> mySet;
auto hint = mySet.begin();
for (int i = 0; i < 10; ++i) {
hint = mySet.insert(hint, i);
}
std::set<int> mySet = {1, 2, 3, 4, 5};
std::vector<int> vec = {1, 2, 3, 4, 5};
std::set<int> mySet;
for (const auto& elem : vec) {
mySet.insert(elem);
}
std::inserter
和算法進行插入操作:std::vector<int> vec = {1, 2, 3, 4, 5};
std::set<int> mySet;
std::copy(vec.begin(), vec.end(), std::inserter(mySet, mySet.end()));
這些技巧可以幫助你更高效地使用C++ set
集合進行插入操作。