当前位置:   article > 正文

C++遍历(traversal)总结_traversal c++

traversal c++

遍历:集合中每个元素一次且仅做一次访问。
C++中存在很多遍历方式,常见如下几种:

  • 传统C for写法
  • 迭代器for写法
  • STL for_each写法
  • C++11迭代器autofor写法
  • C++11 for loop scope写法
  • C++11 STL for_each与lamdba表达式

下面实例说明字符串与向量的遍历。

字符串遍历

string str("abcdefg");

1.传统C for写法 

  1. for(size_t i=0;i<str.size();i++){
  2. cout << str[i] << endl;
  3. }

2.迭代器for写法

  1. for(string::iterator it = str.begin();it != str.end();it++){
  2. cout << *it << endl;
  3. }

 3.STL for_each写法

  1. void print(char c){
  2. cout << c << endl;
  3. }
  4. for_each(str.begin(),str.end(),print);

4.C++11迭代器写法

  1. for(string::iterator it = begin(str);it != end(str);it++){
  2. cout << *it << endl;
  3. }

或者

  1. for(auto it = begin(str);it != end(str);it++){
  2. cout << *it << endl;
  3. }

5. C++ 11 for loop scope写法

  1. for(char c : str){
  2. cout << c << endl;
  3. }

或者

  1. for(auto c : str){
  2. cout << c << endl;
  3. }

 6.C++ 11 STL for_each与lamdba表达式

for_each(begin(str),end(str),[](char c){cout << c << endl;});

向量遍历

  1. vector<int> vec;
  2. vec.push_back(1);
  3. vec.push_back(2);
  4. vec.push_back(3);
  5. vec.push_back(4);
  6. vec.push_back(5);

1.C写法

  1. for(size_t i=0;i<vec.size();i++){
  2. cout << vec[i] << endl;
  3. }

2.迭代器写法

  1. for(vector<int>::iterator it = vec.begin();it != vec.end();it++){
  2. cout << *it << endl;
  3. }

3.STL for_each写法

  1. void print(int n){
  2. cout << n << endl;
  3. }
  4. for_each(vec.begin(),vec.end(),print);

4.C++11迭代器写法

  1. for(vector<int>::iterator it = begin(vec);it != end(vec);it++){
  2. cout << *it << endl;
  3. }

或者

  1. for(auto it = begin(vec);it != end(vec);it++){
  2. cout << *it << endl;
  3. }

5.C++ 11 for新语法写法

  1. for(int n : vec){
  2. cout << n << endl;
  3. }

或者

  1. for(auto n : vec){
  2. cout << n << endl;
  3. }

6.C++ 11 STL for_each与lamdba表达式

for_each(begin(vec),end(vec),[](int n){cout << n << endl;});

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/398971
推荐阅读
相关标签
  

闽ICP备14008679号