循环遍历向量的每个元素

Looping through each element of a vector

本文关键字:元素 遍历 向量 循环      更新时间:2023-10-16

假设我有一个向量,它包含4个元素。我需要先循环通过向量,然后循环通过每个元素,循环通过一个字符数组[元音]以及计算这个单词包含多少元音。

    for(int i = 0; i < b.size(); i++) 
    {
      for(int j = 0; j < b[i].size(); j++) 
       {
         for(int v = 0 ; v < sizeof( vowels ) / sizeof( vowels[0] ); v++)
          if(//blabla)
       }
    }

所以我的问题是,我如何循环遍历每个单词,我的意思是b[i][j]是正确的方法?

如果是的话,这个表格会很好用吗?:

if(b[i][j] == vowels[v]) {
//blabla
}

谢谢。

如果你认真学习C++,你应该看看更高级的方法:不要使用索引和随机访问,使用高级STL函数。考虑:

#include <algorithm>
#include <iostream>
#include <map>
#include <numeric>
#include <set>
#include <string>
#include <vector>
bool is_vowel(char s) {
    static const char vowels[] = { 'a', 'e', 'i', 'o', 'u' };
    const char* vbegin = vowels;
    const char* vend = vowels + sizeof(vowels)/sizeof(char);
    return (std::find(vbegin, vend, s) != vend);
}
std::string::difference_type count_vowels(const std::string& s) {
    return std::count_if(s.begin(), s.end(), is_vowel);
}
template <class T> void printval(const T& obj) { std::cout << obj << std::endl; }
int main() {
    std::vector<std::string> b;
    b.push_back("test");
    b.push_back("aeolian");
    b.push_back("Mxyzptlk");
    std::vector<int> counts(b.size());
    std::transform(b.begin(), b.end(), counts.begin(), count_vowels);
    std::for_each(counts.begin(), counts.end(), printval<int>);
    int total = std::accumulate(counts.begin(), counts.end(), 0);
    printval(total);
    return 0;
}

您编写的循环大致对应于以下行:

 std::transform(b.begin(), b.end(), counts.begin(), count_vowels);
 ..
 std::count_if(s.begin(), s.end(), is_vowel);
 ..
 std::find(vbegin, vend, s)

这使用了一种高级函数/通用编程习惯用法,C++在实现IMO方面并不总是很优雅。但在这种情况下,它工作得很好。

请参阅字符串中元音的计数,了解我认为您正在尝试解决的部分问题的解决方案。您也可以在那里看到各种可接受的循环/迭代技术。

std::vector<T>定义了T operator[](int)。这意味着您可以通过x[i]访问向量x的元素i

std::string定义了char operator[](int),它返回字符串中该位置的char

因此,如果您有一个名为xstd::vector<std::string>x[i][j]将在向量的i位置返回字符串的第j个字符。

这不是惯用的C++方法——最常见的方法是迭代器(.begin().end()调用)。但由于矢量访问是恒定时间的(字符串访问也是如此),所以这并不是什么大不了的事。