Pourquoi ce petit programme ne fonctionne pas

Résolu
Utilisateur anonyme -  
 Utilisateur anonyme -
Bonjour,
pourquoi ce petit programme ne fonctionne pas??????

#include <stdio.h>
#include <conio.h>

void punition(int nombreLigne)
{
int i;
char phrase[90];

for(i=0;i<nombreLigne;i++)
{
printf("%s\n",phrase);
}
}

int main(void)
{
int nbr;
char copie[90];
printf("Entrez le nombre de ligne:");
scanf("%i",&nbr);
printf("Entrez la phrase a répéter:");
scanf("%s",&copie);
punition(nbr,copie);
getch();
}

16 réponses

defcon
 
bon je ne suis pas un "pro" de l'informatique mais essai ca : (bon je n'ai surement pas tout vu encore ...)

#include <stdio.h>
#include <conio.h>

void punition(int nombreLigne)
{
int i;
char phrase[90];
i=0;

for(i=0;i<nombreLigne;i++) \\tu dois définir le nombre de ligne avant cette boucle
{
printf("%s",phrase);
}
}

int main(void)
{
int nbr;
char copie[90];
printf("Entrez le nombre de ligne:");
scanf("%d",&nbr);
printf("Entrez la phrase a répéter:");
scanf("%s",&copie);
punition(nbr,copie);
getch();
}
0
Utilisateur anonyme
 
euhhh au fait je ne dois pas définir le nombre de ligne avant le int main(void)

car normalement la partie avant le int main(void) je dois l'enregistrer dans une librairie et appeler cette librairie

est ce que je me fait comprendre???????
0
defcon
 
Heu oui mais dans ce cas ce n'est pas une librairie mais un sous programme non ??? la je ne sait pas trop car je n'est pas encore vu ca ...

bon ormis ca , ton programme est en c ou en c++ ??
0
Utilisateur anonyme
 
en C

euhh oui c'est un sous programme dsl
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Utilisateur anonyme
 
ahhh j'ai trouvé d'ou venais mon erreur

j'avais marqué ca = void punition(int nombreLigne)
alors que je devais marqué = void punition(int nombreLigne, char phrase[90])


ce problème est résolu mais maintenant quand je marque la phrase a répéter, il ne me marque que le premier mot

que dois je faire?????
0
defcon
 
ok c'est en c, bon je vien de commencer la programmation cette année donc je suis pas un bon mais ca me parrait bizzard que ton sous programme resemble a une bibliothèque ?

haaaa je sait si j'ai bien compris mon cours le scanf ne prend que un seul caractère il se termine dès que tu à un espace dans ta phrase à répéter, c'est ca ?
0
Utilisateur anonyme
 
oui excactement il se termine dés qu'il y a un espace



et moi aussi je commence la programmation cette année :-) :-):-):-):-):-):-)
0
defcon
 
alors il faut donc remplacer ton dernier scanf ... ( je suis en geii ^^)
mais je ne me rappel plus par quoi ...dsl
Ormis ce probleme je ne vois que l'histoire du nombredeligne qui doit etre mal défini.
Par contre ton programme tel quel n'affiche pas les lignes autant de fois que voulu on est d'accord ?
0
Utilisateur anonyme
 
ben maintenant comme il est est la

si je lui dit nombre ligne =5
et la phrase est "bonjour a tous"

il va m'afficher

bonjour
bonjour
bonjour
bonjour
bonjour

donc le nombre de ligne fonctionne
0
Pacorabanix Messages postés 3248 Date d'inscription   Statut Membre Dernière intervention   663
 
le problme est que scanf arrette la lecture après le premier espace.

Tu peux le voir en essayant de faire directement printf("La phrase à copier %d fois est %s", nbr, copie) juste après ton scanf.

Il faut utiliser une autre fonction je pense.
0
defcon
 
bah c'est bon si ton programme t'affiche ca c'est bien le scanf qui ne marche pas ^^ au moins on sait d'ou ca vient ... la je regarde mon cours pour voir ce qu'on peut mettre à la place
0
defcon
 
C'est bon j'ai trouvé (enfin normalement ^^) essai cette fonction à la place de ton dernier scanf et dit moi :

gets(copie[])
char copie[90];
gets(copie);
0
Pacorabanix Messages postés 3248 Date d'inscription   Statut Membre Dernière intervention   663
 
Je viens de trouver un truc qui ressemble : en fait il faut faire un " tableau de chaines "... comme dans la solution proposée ci dessus je crois.
0
Utilisateur anonyme
 
il me met une erreur et me souligne la ligne gets(copie[])
0
Utilisateur anonyme
 
euhh en remplacant scanf("%s"copie)
par
gets(copie);
gets(copie);
sa fonctionne mais je vois pas pourquoi je dois le mettre deux fois
0
defcon
 
oui c'est fort probable vu que les cours de mon prof sont souvent faux ... bon bah là dsl mais je ne peut pas t'aider plus sans voir le programme sur écran, mais ce qui est sur c'est que c'est bien cette fonction que tu dois utiliser mais tu dois chercher des info sur cette fonction car je n'en ai pas plus et j'ai moi même un projet d'info à faire et je n'y arrvie pas donc voila ...
bon courage quand même ^^
0
defcon
 
au final ton programme marche ????
0
Utilisateur anonyme
 
oui maintenant tout fonctionne!!!
0