我想做类似这样的事情:
for (int p : colourPos[i+1])
我如何跳过我的 colourPos
向量的第一次迭代?
我可以使用.begin()
和.end()
吗?
std::views::drop
,结合range-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
注意: 我不建议使用包含begin()
和/或end()
的解决方案,因为基于范围的for循环的思想是摆脱迭代器。如果你需要迭代器,那么我建议仍然使用基于迭代器的for循环。
#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
#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
做这个:
bool first = true;
for (int p : colourPos)
{
if (first)
{ first = false; continue; }
// ...
}
bool first = true; for (int p : colourPos) { if (first) { first = false; continue; } // ... code here }
- NetVipeCfirst = 1;
然后if (first == 1) { first = 0; continue; }
? - Marc Bstd::for_each
而不是基于范围的for循环? - YoungJohnstd::for_each
建议。std::foreach(std::begin(colourPos)+1, std::end(colourPos), [](){//...});
会更加简洁。 - Paul[](){//...});
这一部分,我需要在这里使用什么? - mrmike[](int p){//...}
。你应该把你要做的事情放在我写有//...
的for循环里。[](){}
是C++11语法中lambda函数的表示方式。它只是一个未命名的函数,你将其传递给了std::for_each
。这只是一种不同的说法,相当于void doStuff(int p){//...} std::foreach(std::begin(colourPos)+1, std::end(colourPos), doStuff);
。 - Paul