作者:大可 | 来源:互联网 | 2022-12-09 14:36
我想std::vector
在for循环中迭代一些s,但是根据某些条件,向量应该向前或向后迭代.我想,我可以通过使用普通迭代器或反向迭代器来轻松实现,如下所示:
#include
#include
using namespace std;
int main() {
vector vec{0, 1, 2, 3, 5, 6, 7};
bool reverse = true;
std::iterator it, end_it;
if (reverse) {
it = vec.rbegin();
end_it = vec.rend();
} else {
it = vec.begin();
end_it = vec.end();
}
for (; it != end_it; it++) {
cout <<*it <<", ";
}
return 0;
}
但不幸的是vector::begin()
,vector::rbegin()
似乎并没有使用相同的父类.是否有另一种方法可以做我想要的,而不在if-else结构中有两个不同的循环?当然我可以为循环体创建一个函数/ lambda或者使用一些索引算法但是有更优雅的方法吗?
编译器抱怨分配,it = vec.begin()
因为它们是不同的类型.gcc和VC++输出不同的错误,似乎使用不同的类型作为返回值vector::begin
.