Skocz do zawartości

Podział na wersy


Pentalinio

Rekomendowane odpowiedzi

Poszukuję prostego algorytmu dzielenia tekstu na wersy, czyli np tekst:

Bufor = "Parametr1\nParametr2\nParametr3";

Na:

wers[0] = "Parametr1";
wers[1] = "Parametr2";
wers[2] = "Parametr3";

Prawie wszystko dobrze miałem, ale w 100% celu nie potrafię osiągnąć. Najchętniej chciałbym, aby było to typy std::string, abym mógł używać funkcji substr(), find_first_of() oraz find_first_not_of() ;) . Za pomoc dziękuję.

Odnośnik do komentarza
Udostępnij na innych stronach

#include <iostream>

int main()
{
    std::string str = "bleeeee\nxD\nblaaa";

    std::string rows[10];
    int rows_size = 0;

    int foundn = -1;
    int foundl = 0;
    do
    {
        foundl = foundn + 1;
        foundn = str.find( "\n", foundl );

        rows[rows_size] = str.substr( foundl, foundn - foundl );
        rows_size++;
    }
    while( foundn != std::string::npos );

    for( int i = 0; i < rows_size; i++ )
        std::cout << rows[i] << " ";

    return 0;
}

Ew. można na dynamicznych tablicach. ;)

 

EDIT

Ok, podam odrazu i dla dynamicznych bo będą pytać. =D

#include <iostream>
#include <vector>

int main()
{
    std::string str = "bleeeee\nxD\nblaaa";

    std::vector<std::string> rows;

    int foundn = -1;
    int foundl = 0;
    do
    {
        foundl = foundn + 1;
        foundn = str.find( "\n", foundl );

        rows.push_back( str.substr( foundl, foundn - foundl ) );
    }
    while( foundn != std::string::npos );

    for( int i = 0; i < rows.size(); i++ )
        std::cout << rows[i] << " ";

    return 0;
}

Odnośnik do komentarza
Udostępnij na innych stronach

Jeśli chcesz dodać odpowiedź, zaloguj się lub zarejestruj nowe konto

Jedynie zarejestrowani użytkownicy mogą komentować zawartość tej strony.

Zarejestruj nowe konto

Załóż nowe konto. To bardzo proste!

Zarejestruj się

Zaloguj się

Posiadasz już konto? Zaloguj się poniżej.

Zaloguj się
  • Ostatnio przeglądający   0 użytkowników

    • Brak zarejestrowanych użytkowników przeglądających tę stronę.
×
×
  • Dodaj nową pozycję...