容器迭代器使用技巧

发布时间:2024-09-10 12:25:53 作者:小樊
来源:亿速云 阅读:86

容器迭代器是一种用于遍历容器中元素的对象

  1. 使用auto关键字简化迭代器类型:
std::vector<int> vec = {1, 2, 3, 4, 5};
for (auto it = vec.begin(); it != vec.end(); ++it) {
    std::cout << *it << " ";
}
  1. 使用范围for循环(C++11及更高版本):
std::vector<int> vec = {1, 2, 3, 4, 5};
for (const auto &element : vec) {
    std::cout<< element << " ";
}
  1. 使用反向迭代器:
std::vector<int> vec = {1, 2, 3, 4, 5};
for (auto it = vec.rbegin(); it != vec.rend(); ++it) {
    std::cout << *it << " ";
}
  1. 使用std::next和std::prev移动迭代器:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it = vec.begin();
std::cout << *std::next(it)<< std::endl; // 输出2
std::cout << *std::prev(std::next(it, 2))<< std::endl; // 输出1
  1. 使用std::distance计算两个迭代器之间的距离:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it1 = vec.begin();
auto it2 = vec.begin() + 2;
std::cout<< std::distance(it1, it2)<< std::endl; // 输出2
  1. 使用std::advance移动迭代器:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it = vec.begin();
std::advance(it, 2);
std::cout << *it<< std::endl; // 输出3
  1. 在遍历过程中删除元素:
std::list<int> lst = {1, 2, 3, 4, 5};
for (auto it = lst.begin(); it != lst.end();) {
    if (*it % 2 == 0) {
        it = lst.erase(it);
    } else {
        ++it;
    }
}
  1. 使用std::find查找元素:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it = std::find(vec.begin(), vec.end(), 3);
if (it != vec.end()) {
    std::cout << "Found: " << *it<< std::endl;
} else {
    std::cout << "Not found"<< std::endl;
}
  1. 使用std::lower_bound、std::upper_bound和std::equal_range查找元素:
std::set<int> s = {1, 2, 3, 4, 5};
auto lb = std::lower_bound(s.begin(), s.end(), 3);
auto ub = std::upper_bound(s.begin(), s.end(), 3);
auto er = std::equal_range(s.begin(), s.end(), 3);
  1. 使用std::for_each应用函数于容器中的每个元素:
std::vector<int> vec = {1, 2, 3, 4, 5};
std::for_each(vec.begin(), vec.end(), [](int x) { std::cout << x << " "; });

这些技巧可以帮助你更有效地使用容器迭代器。请注意,这里给出的示例主要针对C++标准库容器,但许多技巧也适用于其他容器类型。

推荐阅读:
  1. c++柔性数组是什么
  2. C++寄存器怎么优化

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++

上一篇:字符串处理库函数选择

下一篇:C++内存管理库函数

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》