跳过基于范围的循环的第一次迭代

时间:2014-09-03 19:46:40

标签: c++ for-loop vector iteration

for (int p : colourPos[i+1])

如何跳过colourPos向量的第一次迭代?

我可以使用.beginend吗?

3 个答案:

答案 0 :(得分:9)

Live demo link.

#include <iostream>
#include <vector>
#include <iterator>
#include <cstddef>

template <typename T>
struct skip
{
    T& t;
    std::size_t n;
    skip(T& v, std::size_t s) : t(v), n(s) {}
    auto begin() -> decltype(std::begin(t))
    {
        return std::next(std::begin(t), n);
    }
    auto end() -> decltype(std::end(t))
    {
        return std::end(t);
    }
};

int main()
{
    std::vector<int> v{ 1, 2, 3, 4 };

    for (auto p : skip<decltype(v)>(v, 1))
    {
        std::cout << p << " ";
    }
}

输出:

2 3 4

或更简单:

Yet another live demo link.

#include <iostream>
#include <vector>

template <typename T>
struct range_t
{
    T b, e;
    range_t(T x, T y) : b(x), e(y) {}
    T begin()
    {
        return b;
    }
    T end()
    {
        return e;
    }
};

template <typename T>
range_t<T> range(T b, T e)
{
    return range_t<T>(b, e);
}

int main()
{
    std::vector<int> v{ 1, 2, 3, 4 };

    for (auto p : range(v.begin()+1, v.end()))
    {
        std::cout << p << " ";
    }
}

输出:

2 3 4

答案 1 :(得分:8)

这样做:

bool first = true;

for (int p : colourPos)
{
    if (first)
    { first = false; continue; }

    // ...
}

答案 2 :(得分:6)

由于 C++20,您可以使用 std::views::drop 中的范围适配器 Ranges libraryrange-based for loop 一起跳过第一个元素,如下所示:

std::vector<int> colourPos { 1, 2, 3 };

for (int p : colourPos | std::views::drop(1)) {
    std::cout << "Pos = " << p << std::endl;
}

输出:

<块引用>

位置 = 2
位置 = 3

Code on Wandbox

注意:我不建议使用包含 begin() 和/或 end() 的解决方案,因为基于范围的 for 循环的想法是摆脱迭代器。如果您需要迭代器,那么我会坚持使用基于迭代器的 for 循环。