logo

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)