跳到主要内容

std::set begin() 方法

// Non const version
iterator begin() noexcept;

// Const version
iterator begin() const noexcept;

// Const version
const_iterator cbegin() const noexcept;

返回指向数组末尾之后元素的迭代器

指向 set 的第一个元素。如果 set 为空,返回的迭代器将等于 end()

参数

(无)

返回值

指向第一个元素的迭代器。

异常

(无)

复杂度

常数 - O(1)

begin 和 cbegin 的区别

对于 const 容器 c,begin 和 cbegin 是相同的 - c.begin() == c.cbegin()

对于非常量类型c的容器,它们返回不同的迭代器

#include <set>

int main()
{
std::set<int> set = {1, 2, 3, 4, 5};
auto it = set.begin(); // Type: std::set<int>::iterator
*it = 5; // ✔ Ok
}

示例

Main.cpp
#include <algorithm>
#include <iostream>
#include <set>

int main() {
std::set<int> set = { 3, 1, 4, 1, 5, 9, 2, 6, 5 };
std::for_each(set.cbegin(), set.cend(), [](int x) {
std::cout << x << ' ';
});
std::cout << '\n';
}
输出
1 2 3 4 5 6 9
本文来源于此 CppReference 页面。它可能因改进或编辑偏好而有所改动。点击“编辑此页面”查看本文档的所有改动。
悬停查看原始许可证。

std::set begin() 方法

// Non const version
iterator begin() noexcept;

// Const version
iterator begin() const noexcept;

// Const version
const_iterator cbegin() const noexcept;

返回指向数组末尾之后元素的迭代器

指向 set 的第一个元素。如果 set 为空,返回的迭代器将等于 end()

参数

(无)

返回值

指向第一个元素的迭代器。

异常

(无)

复杂度

常数 - O(1)

begin 和 cbegin 的区别

对于 const 容器 c,begin 和 cbegin 是相同的 - c.begin() == c.cbegin()

对于非常量类型c的容器,它们返回不同的迭代器

#include <set>

int main()
{
std::set<int> set = {1, 2, 3, 4, 5};
auto it = set.begin(); // Type: std::set<int>::iterator
*it = 5; // ✔ Ok
}

示例

Main.cpp
#include <algorithm>
#include <iostream>
#include <set>

int main() {
std::set<int> set = { 3, 1, 4, 1, 5, 9, 2, 6, 5 };
std::for_each(set.cbegin(), set.cend(), [](int x) {
std::cout << x << ' ';
});
std::cout << '\n';
}
输出
1 2 3 4 5 6 9
本文来源于此 CppReference 页面。它可能因改进或编辑偏好而有所改动。点击“编辑此页面”查看本文档的所有改动。
悬停查看原始许可证。