如何跳过基于范围的 for 循环的第一次迭代?
                            本文介绍了如何跳过基于范围的 for 循环的第一次迭代?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
                        
                        问题描述
我想做这样的事情:
for (int p : colourPos[i+1])
如何跳过我的 colourPos 向量的第一次迭代?
How do I skip the first iteration of my colourPos vector?
我可以使用 .begin() 和 .end() 吗?
Can I use .begin() and .end()?
推荐答案
现场演示链接.
#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
<小时>
或者更简单:
Or simpler:
又一个现场演示链接.
#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
                        这篇关于如何跳过基于范围的 for 循环的第一次迭代?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
