Pentalinio Opublikowano 6 Stycznia 2008 Udostępnij Opublikowano 6 Stycznia 2008 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 Więcej opcji udostępniania...
Tymon Opublikowano 6 Stycznia 2008 Udostępnij Opublikowano 6 Stycznia 2008 #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 Więcej opcji udostępniania...
Rekomendowane odpowiedzi
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ę