在容器(向量)上以循环方式循环的最佳方法是什么?

时间:2014-01-27 19:27:02

标签: c++ boost

我需要在容器上循环循环,这样对于每次迭代,我都可以访问当前和前一个元素。对于第一次迭代,前一个元素应该是容器的back元素。

这个例子是这样做的:

#include <vector>
#include <iostream>

using namespace std;

int main(int argc, const char *argv[])
{
    vector<int> v = {0,1,2,3,4,5,6}; 

    auto xPreviousIt = v.end(); 
    --xPreviousIt; 

    int i = 0; 
    for (auto xCurrent : v)
    {
        cout << xCurrent <<  "  " << *xPreviousIt << endl; 
        xPreviousIt = v.begin() + i;  
        ++i; 
    }

    return 0;
}

但我想知道是否有更好的方法来实现这样的目标?就像一个圆形的迭代器,它从一个容器的开始处开始并在那里结束?我在boost中找到的只有circular buffer

1 个答案:

答案 0 :(得分:2)

使用普通的for循环更简单。如果例如init是起始索引,那么你可以写

for ( std::vector<int>::size_type i = 0; i < v.size(); i++ )
{
   std::cout << v[( init + i ) % v.size()] << ' ';
}

std::cout << std::endl;