Como faço para iterar sobre as palavras de um fio?

I'estou tentando iterar sobre as palavras de um fio.

A cadeia pode ser assumida como sendo composta de palavras separadas por espaço em branco.

Note que I'não estou interessado nas funções de string C ou nesse tipo de manipulação/acesso de caracteres. Além disso, por favor dê precedência à elegância sobre a eficiência em sua resposta.

A melhor solução que eu tenho neste momento é:

#include <iostream>
#include <sstream>
#include <string>

using namespace std;

int main()
{
    string s = "Somewhere down the road";
    istringstream iss(s);

    do
    {
        string subs;
        iss >> subs;
        cout << "Substring: " << subs << endl;
    } while (iss);
}

Há uma maneira mais elegante de fazer isto?

Esta é a minha maneira favorita de iterar através de um fio. Podes fazer o que quiseres por palavra.

string line = "a line of text to iterate through";
string word;

istringstream iss(line, istringstream::in);

while( iss >> word )     
{
    // Do something on `word` here...
}
Comentários (3)

O STL ainda não tem um método desse tipo disponível.

Entretanto, você pode utilizar a função C's [strtok()][1] utilizando o membro [std::string::c_str()][2], ou você pode escrever o seu próprio. Aqui está um exemplo de código que encontrei após uma rápida busca no Google ("STL string split"):

void Tokenize(const string& str,
              vector& tokens,
              const string& delimiters = " ")
{
    // Skip delimiters at beginning.
    string::size_type lastPos = str.find_first_not_of(delimiters, 0);
    // Find first "non-delimiter".
    string::size_type pos     = str.find_first_of(delimiters, lastPos);

    while (string::npos != pos || string::npos != lastPos)
    {
        // Found a token, add it to the vector.
        tokens.push_back(str.substr(lastPos, pos - lastPos));
        // Skip delimiters.  Note the "not_of"
        lastPos = str.find_first_not_of(delimiters, pos);
        // Find next "non-delimiter"
        pos = str.find_first_of(delimiters, lastPos);
    }
}

Extraído de:

Se você tiver perguntas sobre a amostra de código, deixe um comentário e eu explicarei.

E só porque não implementa um 'tippedef' chamado iterator ou sobrecarregar o '

Comentários (10)

Usando std::stringstream como você tem funcionado perfeitamente bem, e fazer exatamente o que você queria. Se você'está apenas procurando por uma maneira diferente de fazer as coisas, você pode utilizar [std::find()][1]/[std::find_first_of()][2] e [std::string::substr()][3].

Aqui's um exemplo:


#include 
#include 

int main()
{
    std::string s("Somewhere down the road");
    std::string::size_type prev_pos = 0, pos = 0;

    while( (pos = s.find(' ', pos)) != std::string::npos )
    {
        std::string substring( s.substr(prev_pos, pos-prev_pos) );

        std::cout 
Comentários (1)