CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

Probleme de boucle en c++

Raahhh
Raahhh
Niveau 8
12 février 2006 à 13:58:50

Bien le bonjour !
J´ai un certain probleme avec une boucle en c++ comme vous avez pu le lire ds mon titre.

Je vous mets le code source ici bas :

  1. include <iostream>

using namespace std;
char no[4];
int main()
{
cout<<"veus-tu quitter ?" <<endl;
cin>>no;
while(no=="non")
{
cout<<"veus-tu quitter ?" <<endl;
cin>>no;
}
return 0;
}

Le probleme c ke on arrive pas a entrer ds la boucle meme si on initialise no avec non au dessus.
La fenetre c++ s´ouvre et je mets non puis entree et ca me ferme la fenetre au lieu de faire une iteration. Quelqu´un pourrait m´aider a resoudre ce probleme ?

J´ai vu ds un otre post kan jai fait rechercher des "dechets" avec scanf est ce la meme chose pour cin ?

Je vous en serai gré de répondre et si possible gentiment. Merci.

Virtuality
Virtuality
Niveau 8
12 février 2006 à 14:24:01

Pour garder le code le plus semblable au tien, ça donnerais ça :

  1. include <iostream>

using namespace std;

char no[5];

int main()
{
cout<<"veus-tu quitter ?" <<endl;
cin>>no;
while(!strcmp(no,"non"))
{
cout<<"veus-tu quitter ?" <<endl;
cin>>no;
}

return 0;
}

Raahhh
Raahhh
Niveau 8
12 février 2006 à 14:28:43

Donc celui la marcherait ?

Quel est l´utilité de !s trcmp ?
Je ne l´ai jamais vu.

Virtuality
Virtuality
Niveau 8
12 février 2006 à 14:33:34

Ca marche oui...
J´ai fais le plus semblable possible au tiens (j´ai même laissé la faute d´orthographe à "veux-tu" :-p ).
Le strcmp fait ce que ta précédente comparaison ne pouvait pas faire^^
il compare ton char avec ton const char et renvoie 0 s´ils sont égaux. Le "!" dis donc "s´ils sont égaux (=> égal à zéro) continuer la boucle.
Mais je vais pas compliquer la chose, je sais même pas si tu connais les pointeurs :)
++

Raahhh
Raahhh
Niveau 8
12 février 2006 à 14:39:53

Ok merci beaucoup !! !

Sinon c´est exact je ne connais pas les pointeurs. Je ne fait ke les bases pour le moment : type, operateur, boucle, condition, etc...

Ah oui la faute :lol: boh c´est pas le plus important :)

Mais sinon tu pourrais m´expliquer pk mon amis disait ke printf et scanf etaient plus maniable que cout et cin si tu sais bien sur ?

Virtuality
Virtuality
Niveau 8
12 février 2006 à 14:45:54

Parce que c´est probablement un défenseur de la cause du C.

Et au contraire, printf et scanf sont bien moins extensibles et maniable...
Le plus flagrant dans l´écriture est le fait que tu n´a pas besoin de spécifier le type avec iostream, ce qui est déjà bien pratique voir plus.
Après il y a plein d´autres petits trucs qui font que stdio se fait qq peu vieu que je ne connais pas :)
Il y a plein de pros ici qui pourront te renseigner mieux que moi. :)

Raahhh
Raahhh
Niveau 8
12 février 2006 à 14:53:55

Tres bien Merci beaucoup de ces réponses :)

De toutes facon je n´aurais pas utiliser printf et scanf, cout et cin sont bocoup plus facile a s´en souvenir :)

dnob700
dnob700
Niveau 10
12 février 2006 à 20:16:19

Si tu utilise cin et cout, je te coneille d´utiliser les variable de type "string" plutot que "char*" pour tes chaines de caractères.
Car elles sont bien pls pratiques à utiliser : si dans ton premier programme (en haut de cette page), tu remplace la ligne
char no[4];
par la ligne
string no;
alors d´un seul coup, il va fonctionner, car là tu as le droit de comparer deux chaines de caractères avec l´opérateur ==.

Raahhh
Raahhh
Niveau 8
13 février 2006 à 15:38:50

Ok merci Dnob. Je ne connaissais pas ce que c´etait string, je l´avais vu ds mon livre en feuilletant vers la fin.

Donc string est un type alors.

gollumkawder
gollumkawder
Niveau 10
13 février 2006 à 17:27:22

wai, c´est communément pour les chaines de caractère, après ça peut se trouver aussi chez les hommes mais je préfere sur une.. hein ? ah oui pardon.

Poulpix
Poulpix
Niveau 6
16 février 2006 à 11:53:51

Fais un do while!!!!

  1. include <iostream>

using namespace std;

char no[5];

int main()
{
do
{

Poulpix
Poulpix
Niveau 6
16 février 2006 à 11:55:23

cout << "veux tu quitter?" << endl;
cin >> no;
}while (strcmp(no,"non")==0);

Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Steam Deck
  • Hardware
La vidéo du moment