Rimozione di spazi da una stringa utilizzando Stringstream
La soluzione per rimuovere gli spazi da una stringa è già stata pubblicata Qui . In questo articolo un'altra soluzione utilizzando stringstream viene discusso.
Algoritmo:
1. Enter the whole string into stringstream. 2. Empty the string. 3. Extract word by word and concatenate to the string.
Programma 1: Utilizzando EOF .
CPP // C++ program to remove spaces using stringstream #include using namespace std ; // Function to remove spaces string removeSpaces ( string str ) { stringstream ss ; string temp ; // Storing the whole string // into string stream ss < < str ; // Making the string empty str = '' ; // Running loop till end of stream while ( ! ss . eof ()) { // Extracting word by word from stream ss >> temp ; // Concatenating in the string to be // returned str = str + temp ; } return str ; } // Driver function int main () { // Sample Inputs string s = 'This is a test' ; cout < < removeSpaces ( s ) < < endl ; s = 'geeks for geeks' ; cout < < removeSpaces ( s ) < < endl ; s = 'geeks quiz is awesome!' ; cout < < removeSpaces ( s ) < < endl ; s = 'I love to code' ; cout < < removeSpaces ( s ) < < endl ; return 0 ; }
Produzione
Thisisatest geeksforgeeks geeksquizisawesome! Ilovetocode
Complessità temporale: O(n) dove n è la lunghezza della stringa
Spazio ausiliario: SU)
Programma 2: Utilizzando getline() .
CPP // C++ program to remove spaces using stringstream // and getline() #include using namespace std ; // Function to remove spaces string removeSpaces ( string str ) { // Storing the whole string // into string stream stringstream ss ( str ); string temp ; // Making the string empty str = '' ; // Running loop till end of stream // and getting every word while ( getline ( ss temp ' ' )) { // Concatenating in the string // to be returned str = str + temp ; } return str ; } // Driver function int main () { // Sample Inputs string s = 'This is a test' ; cout < < removeSpaces ( s ) < < endl ; s = 'geeks for geeks' ; cout < < removeSpaces ( s ) < < endl ; s = 'geeks quiz is awesome!' ; cout < < removeSpaces ( s ) < < endl ; s = 'I love to code' ; cout < < removeSpaces ( s ) < < endl ; return 0 ; } // Code contributed by saychakr13
Produzione
Thisisatest geeksforgeeks geeksquizisawesome! Ilovetocode
Complessità temporale: O(n)
Spazio ausiliario: O(n)