2015-12-29 2 views
0

C'est ma première question ici, donc je serais heureux de recevoir un peu de soutien sur le style que j'ai utilisé pour faire référence à mon problème :). Voici le programme terminé, son but principal est de diviser les mots donnés en deux et de créer des mots remplaçant ceux d'origine. Les mots remplacés sont construits à partir de leurs origines en les divisant en moitiés et en prenant ceux de la première moitié commençant par la première lettre d'un mot. Heres le code complet:Le programme passe dans une boucle infinie

#include <iostream> 
#include <string> 
#include <cstdio> 
#include <math.h> 

using namespace std; 

void obcinaczSlow(int); 

int main(){ 
    int ilosc; 
    cout << "Prosze o podanie ilosci prob: "; 
    cin>>ilosc; 
    cout << endl; 
    obcinaczSlow(ilosc); 
    cin.ignore(); 
    cin.get(); 
    return 0; 
} 

void obcinaczSlow(int ilosc_prob){ 

    int i=0,j=0,dlugosc_slowa=0,dlugosc_polowy=0; 
    string *tablica_slow,budowane_slowo,aktualne_slowo,dodane; 
    tablica_slow = new string [ilosc_prob]; 

    cout << "Prosze o podanie " << ilosc_prob << " slow" << endl; 
    cin.sync(); 
    for(i=0;i<ilosc_prob;i++){ 
     cout << "Prosze o podanie slowa numer: " << i+1 << endl; 
     cin>>aktualne_slowo; 
     tablica_slow[i] = aktualne_slowo; 
    } 

    for(i=0;i<ilosc_prob;i++){ 
     aktualne_slowo = tablica_slow[i]; 
     cout << "Aktualne slowo do przerobienia: " << aktualne_slowo << endl; 
     dlugosc_slowa = aktualne_slowo.length(); 
     cout << "Dlugosc slowa do przerobienia: " << dlugosc_slowa << endl; 
     dlugosc_polowy = floor(dlugosc_slowa/2); 
     cout << "Dlugosc polowy slowa int: " << dlugosc_polowy << endl; 
     budowane_slowo.clear(); 
     dodane.clear(); 
     cout << "Budowane slowo to: " << budowane_slowo << endl; 
     for(j=0;j<=dlugosc_polowy;j=+2){ 
     dodane = aktualne_slowo.at(j); 
     budowane_slowo.append(dodane); 
     } 
     tablica_slow[i] = budowane_slowo; 
    } 

    cout << "Slowa po transformacji wygladaja nastepujaco: " << endl; 
    for(i=0;i<ilosc_prob;i++){ 
    cout << "Slowo o numerze " << i+1 << " : " << tablica_slow[i] << endl; 
    } 
    delete [] tablica_slow; 
    cin.sync(); 
} 

Le problème soulève lorsque le programme atteint la boucle, qui est censé ajouter la lettre pointée par le j-indice en utilisant la méthode de « .at » de la classe de chaîne. Je ne trouve pas de solution même en essayant de le déboguer. Pourriez-vous m'aider :)?

+0

Juste curiou s, la raison des trois votes _close_ (au moment de ce commentaire) est donnée par _off-topic_. Basé sur les balises de ce post, il semble être précisément sur le sujet. Alors, pourquoi les votes vers le bas? – ryyker

+2

@ryyker: Le problème n'a pas été réduit à une petite section de code, et il a été causé par une faute de frappe. Il s'agit d'un référentiel de questions-réponses et il est difficile de voir comment cette question sera utile à tout le monde sauf à l'OP. –

+0

essayez de réduire le code à un cas minime qui reproduit toujours l'erreur. Cela vous aide souvent à comprendre le problème sans avoir à poser une question. – Walter

Répondre

6

Vous avez une faute de frappe ici

for(j=0;j<=dlugosc_polowy;j=+2) 

Je suppose que vous vouliez dire += au lieu de =+

for(j=0;j<=dlugosc_polowy;j+=2) 

Sinon, vous êtes juste assignez 2-j encore et encore.

3

Votre erreur est renversant deux caractères:
Change:

`j=+2` to `j+=2` 
    ^^  ^^ 

(. La façon dont il est écrit j est attribué la valeur de 2, puis, pour le reste de sa vie, reste là-bas)

0
for(j=0;j<=dlugosc_polowy;j=+2){ 
    dodane = aktualne_slowo.at(j); 
    budowane_slowo.append(dodane); 
} 

remplacer le j = + 2 et j + = 2

for(j=0;j<=dlugosc_polowy;j+=2){ 
    dodane = aktualne_slowo.at(j); 
    budowane_slowo.append(dodane); 
}