View Full Version : [C++] Funzione "strtok": chiaritemi please..
Ciao ragazzi!
Qualcuno saprebbe spiegarmi in parole povere (perchè sono un niubbo anche se il prof universitario ci da già come esperti del c plas plas) come funzione strtok?
Ovvero cosa fa e/o come funziona?
[C++]
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char s[] = "Today's date is March 12, 1995.";
char* p;
cout << "La stringa e': [" << s << "]\nI token sono:\n";
p = strtok(s," ");
while (p) {
cout << "\t[" << p << "]\n";
p = strtok(NULL, " ");
}
cout << "Ora la stringa e': [" << s << "]\n";
}
[/C++]
Questo è un semplice esempio, capisco che tronca la stringa s quando trova lo spazio " ", ma per esempio "p = strtok(NULL, " ");" mi lascia un pò perplesso...
:muro: :muro:
Grazie!
maxithron
20-01-2004, 22:27
questo non è certo il massimo ma prima di addentrarci dai uno sguardo qui:
http://www.cplusplus.com/ref/cstring/strtok.html
Strtok si tiene un riferimento interno (leggi una variabile static) che punta al primo elemento da cui cercare la nuova occorrenza...
Quando gli si passa NULL sfrutta questo puntatore per continuare la ricerca...
Originariamente inviato da maxithron
questo non è certo il massimo ma prima di addentrarci dai uno sguardo qui:
http://www.cplusplus.com/ref/cstring/strtok.html
Avevo già guardato quel sito..Purtroppo non mi è stato molto di aiuto per questa funzione..altre volte si è rivelato prezioso..
Thnz
@Cionci: ok, adesso mi sembra già molto + chiaro..
Quindi "p" è un array di stringhe con all'interno i vari pezzi di "s" dove cadono gli spazi, il ciclo serve per far continuare questo spezzettamento fino alla fine della stringa "s" grazie a quel P=strtok(NULL,....) giusto?
..se come primo esame avessimo turbo pascal maledizione :muro:
:sofico:
Thnx
la strtok se non erro è C, e fa veramente schifo ^^'''
mi spiego, fa egregiamente il suo lavoro, ma con delle limitazioni paurose
in c++ gli stessi risultati li si ottengono velocemente con le stl e qualche riga di codice, con molta più soddisfazione secondo me :p
Originariamente inviato da ri
la strtok se non erro è C, e fa veramente schifo ^^'''
mi spiego, fa egregiamente il suo lavoro, ma con delle limitazioni paurose
in c++ gli stessi risultati li si ottengono velocemente con le stl e qualche riga di codice, con molta più soddisfazione secondo me :p
...boh, solo che il nostro prof ce l'ha fatta studiare in c++..
E a quanto vedo, ha tolto dai guai molti studenti delle scorse sessioni di esame... ;)
Per questo mi preme capirla bene.
Tu che dici della "definizione" che ho dato sopra? :confused:
Va bene come hai detto te...
Originariamente inviato da cionci
Va bene come hai detto te...
Grazie :)
(ah, questi niubbi rompi.. :sofico: )
Ciao
Originariamente inviato da nin
Quindi "p" è un array di stringhe
Array di char ;)
xybercom
21-01-2004, 20:41
Originariamente inviato da ri
la strtok se non erro è C, e fa veramente schifo ^^'''
mi spiego, fa egregiamente il suo lavoro, ma con delle limitazioni paurose
in c++ gli stessi risultati li si ottengono velocemente con le stl e qualche riga di codice, con molta più soddisfazione secondo me :p
Concordo, le char* sono tra gli elementi peggiori del C (imho).
A parte il cout il programma comunque è puro C; il tipo string meriterebbe più considerazione, anche in un corso base. Comunque è giusto che nin si studi quello che chiedono all'esame...
Originariamente inviato da xybercom
Comunque è giusto che nin si studi quello che chiedono all'esame...
Eh già, altrimenti non me la passerò molto bene..
:muro:
Grazie a tutti!
xybercom
21-01-2004, 21:29
In bocca al lupo per l'esame, comunque usando la STL il programma io l'avrei scritto così (si può migliorare molto ma sembra funzionare, l'indentazione si è persa nel copia incolla ma basta usare astyle al max):
#include <iostream>
#include <cstring>
#include <vector>
using namespace std;
// break a string into a vector tokens
vector <string> tokenize ( string str )
{
vector <string> result;
string::const_iterator it = str.begin();
while ( it != str.end() )
{
while ( ( *it == ' ') && (it!=str.end() ) ) it++; // skips duplicated spaces
string::const_iterator it2 = it;
while ( ( *it2 != ' ') && (it2!=str.end() )) it2++; // move to the position of the following space
string tmp ( it , it2 ); // copy range [it,it2) to tmp string
result.push_back ( tmp );
it = it2;
}
return result;
}
int main()
{
string s ( "Today's date is March 12, 1995. and the sun shines bright" );
vector<string> tokens = tokenize ( s );
cout << "La stringa e': [" << s << "]\nI token sono " << tokens.size() << " :\n";
for ( uint k=0; k<tokens.size(); k++ )
cout << tokens[k] << " ";
cout << "\n\n fine" << endl;
//cout << "Ora la stringa e': [" << s << "]\n";
}
Originariamente inviato da xybercom
In bocca al lupo per l'esame
Uff, appena finito..
Il programma funzionava, ma chiedeva di implementare una funzione che svolgesse alcune operazioni..
Fino all'ultimo l'ho scritto senza funzione, lasciando tutto nel main..
Quando poi è stato il momento di far andare la funzione..nisbà...
Il valore che tornava era quello giusto, ma poi nel main del programma si perdeva chissà dove..
Damn.. :muro:
Speriamo che comunque mi valutino il fatto che il programma funziona al 100%..
@ xybercom: mh..sinceramente non saprei neppure come leggerlo il tuo esempio! :p
xybercom
22-01-2004, 20:44
Niente di fondamentale comunque la funzione data una stringa ti restituisce un array (un vector è un array "potenziato" :) ) i cui elementi sono le "parole" di cui la stringa è composta.
Originariamente inviato da nin
Uff, appena finito..
Il programma funzionava, ma chiedeva di implementare una funzione che svolgesse alcune operazioni..
Fino all'ultimo l'ho scritto senza funzione, lasciando tutto nel main..
Quando poi è stato il momento di far andare la funzione..nisbà...
Uff..
Mi hanno corretto il compito..
"Corretto, ma fuori tema per la mancanza della funzione. Peccato perchè il programma (per quanto un pò farraginoso) sembra andare bene"
Ho preso 18 :muro:
NOn so se accettarlo o meno, la prova di programmazione non è facile e ho paura che se stavolta mi è andata anche bene chissà la prossima...potrebbe essere un programma allucinante..
Sob e dire che era perfetto..
vBulletin® v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.