Domanda

Una domanda piuttosto veloce ... non posso capire perché questo ciclo non finisce mai ...

#include <iostream>
#include <fstream>

using namespace std;

int main()
{
 //[city1][city2][distance]

 ifstream sourcefile;

 int data[50][50];



 sourcefile.open("a5.txt");
 if(!sourcefile)
 {
  cout << "file not found" << endl;
  return 1;
 }

 int temp1, temp2, temp3, check;

 char reader;

 check = 0;



 while(reader != 'Q')
 {
  sourcefile >> temp1;
  sourcefile >> temp2;
  sourcefile >> temp3;

  data[temp1][temp2] = temp3;

  cout << "data[" << temp1 << "][" << temp2 << "] = " << temp3 << endl;
  check++;

  if(check > 100)
  {
   cout << "overflow" << endl;
   return 1;
  }

  reader = sourcefile.peek();


 }



 return 0;
}

Il file di input

1 2 10
1 4 30
1 5 99    
2 3 50    
2 1 70    
3 5 10    
3 1 50    
4 3 20    
4 5 60    
5 2 40   
Q

L'output:

data[1][2] = 10
data[1][4] = 30
data[1][5] = 99
data[2][3] = 50
data[2][1] = 70
data[3][5] = 10
data[3][1] = 50
data[4][3] = 20
data[4][5] = 60
data[5][2] = 40
data[0][2] = 40
data[0][2] = 40

...
... (repeats "data[0][2] = 40" about 60 more times)
overflow

E 'questo un caso di peek ottenere un personaggio failbit?

È stato utile?

Soluzione

peek consente di vedere il carattere successivo, che mi sembra in questo caso è il ritorno a capo dopo il valore della distanza. dato che non è Q, il ciclo tenta di leggere altri tre valori interi, non riesce, e imposta il bit di errore. sbirciatina, quando c'è un fallimento, ritorna EOF -. in modo da non arrivare a vedere la Q

Altri suggerimenti

tentare di risolverli prima di iniziare a leggere dal file.

sourcefile >> std::skipws;

Si farà gli spazi bianchi come interruzione di riga per essere ignorato.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top