std::set 遍历
时间: 2023-09-08 15:13:23 浏览: 59
在 C++ 中,std::set 是一个标准库容器,用于存储一组唯一的元素,并按照特定的顺序进行排序。要遍历 std::set,可以使用迭代器或范围基于循环。
以下是使用迭代器遍历 std::set 的示例代码:
```cpp
#include <iostream>
#include <set>
int main() {
std::set<int> mySet = {1, 2, 3, 4, 5};
// 使用迭代器遍历 set
for (auto it = mySet.begin(); it != mySet.end(); ++it) {
std::cout << *it << " ";
}
return 0;
}
```
输出结果将是:1 2 3 4 5。
另外,你也可以使用范围基于循环来遍历 std::set,如下所示:
```cpp
#include <iostream>
#include <set>
int main() {
std::set<int> mySet = {1, 2, 3, 4, 5};
// 使用范围基于循环遍历 set
for (const auto& element : mySet) {
std::cout << element << " ";
}
return 0;
}
```
输出结果也将是:1 2 3 4 5。
希望这能帮助到你!如果你有任何其他问题,请随时提问。
相关问题
std::set 反向遍历
可以使用 std::set 的反向迭代器来实现反向遍历。例如:
```c++
#include <iostream>
#include <set>
int main() {
std::set<int> my_set = {1, 2, 3, 4, 5};
// 正向遍历
for (auto it = my_set.begin(); it != my_set.end(); ++it) {
std::cout << *it << " ";
}
std::cout << std::endl;
// 反向遍历
for (auto it = my_set.rbegin(); it != my_set.rend(); ++it) {
std::cout << *it << " ";
}
std::cout << std::endl;
return 0;
}
```
输出结果为:
```
1 2 3 4 5
5 4 3 2 1
```
std::set相加
std::set没有直接的相加操作。std::set是一个有序容器,其中的元素是唯一且按升序排列的。要对std::set中的元素进行加法操作,可以使用std::transform算法结合一个自定义的函数对象来实现。例如,可以使用std::transform算法将两个std::set进行元素相加,并将结果存储在另一个std::set中。以下是一个示例代码:
```cpp
#include <iostream>
#include <algorithm>
#include <set>
struct AddOperation {
int operator()(int a, int b) const {
return a + b;
}
};
int main() {
std::set<int> set1 = {1, 2, 3, 4, 5};
std::set<int> set2 = {6, 7, 8, 9, 10};
std::set<int> result;
std::transform(set1.begin(), set1.end(), set2.begin(), std::inserter(result, result.begin()), AddOperation());
std::cout << "The result of std::set addition is:";
for (int num : result) {
std::cout << " " << num;
}
std::cout << std::endl;
return 0;
}
```
以上代码中,我们定义了一个名为AddOperation的函数对象,它将两个整数相加。然后,我们使用std::transform算法将set1和set2中的元素逐对相加,并将结果插入到结果集合result中。最后,我们遍历结果集合并将结果打印出来。
请注意,这只是一个示例,你可以根据实际需求自定义自己的函数对象来执行不同的操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [std::transform和 std::for_each](https://blog.csdn.net/yudelian/article/details/119741093)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]