C ++:使用各种方法遍历向量的用例

问题描述

自从我最近开始使用c ++ STL库以来,我发现有很多方法可以遍历一个向量,其中一些是-:

vector<int> V
for(int i=0; i<V.size(); ++i) //using index based method

for(auto it=V.begin(); it != V.end(); ++it) //using iterator based method

for(const auto& x : V) //using range based loop

所以我的问题是,哪种方法最有效,何时使用其余方法

解决方法

都不是。您应该改用range-based for loop

vector<int> vv;
...
for( const auto& x : vv )
{
        // ...
}
,

如果您正在遍历向量,而实际上并不需要存储任何索引,则range-based for loop(如另一个答案中所述)就足够了。如果您确实关心索引,那么最好的方法可能是使用标准的for (int i = 0; i < vector.size(); i++) doSomething(vector[i]);。如果需要迭代器,则可以使用迭代器来初始化前一个循环。每种方法都提供了不同的方式来访问相同的数据。这完全取决于您的需求。

基本上:

  • 基于范围的for循环(更方便的语法)
  • 使用索引(除了遍历需要索引的向量之外,您可能还需要做其他事情)
  • 使用迭代器(您可能需要迭代器用于其他功能)