Probleme en c

Fermé
hillal2 - 20 nov. 2010 à 15:57
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 - 20 nov. 2010 à 22:49
Bonjour,
je suis un débâtant en langage C
j'ai un problème dans un exercice :
pour crée un dictionnaire en C
coude source et
/**********************************************/
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
main(){
//declaration //
char *pch, test, ch, c;
int i, j, n;
int *pabc;
// cree table abc //
int abc[]={};
// demande de nbr de carrachtere//
printf("donner le nombre de carractere : ");
scanf("%d",&n);
// redimontion de pch : char //
pch = (char*) calloc ( n , sizeof ( char ) );
if ( pch == NULL ){
fprintf(stderr,"allocation imposible");
exit (0);
}
// remplissage pch : char //
for(i=0; i<=n-1; i++){
printf("Taper le carractere %d : ",i+1);
scanf("%s",&pch[i]);
getchar();
}
// redimontion de table pabc ///
pabc = (int*) calloc ( n , sizeof ( int ) );
if ( pabc == NULL ){
fprintf(stderr,"allocation imposible");
exit (0);
}
// test sur occurance //
for(i=0; i<=n-1; i++){
c = 0;
for(j=0; j<=n-1; j++){
if(pch[i] == pch[j]){
c = c + 1;
}
}
abc[i] = c;

}
// affichage //
for(i=0; i<=n-1; i++){
printf(" %c => : %d \n",pch[i],pabc[i]);
}
// fin //
getch();
}

/**********************************************/

j'attend le réponse et merci pour tout

2 réponses

fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 840
20 nov. 2010 à 21:49
Bonjour,

Pas mal d'erreurs en effet.
main(){
Il faut mettre : int main (void) { car main renvoie un int.

int abc[]={};
Le compilateur ne devrait pas trop aimer puisqu'il ne peut pas déterminer la taille du tableau. Il faut que tu spécifies la taille minimum ou que tu définisses la liste.

printf(stderr,"allocation imposible");
Vaut mieux mettre printf(stderr,"allocation impossible\n"); pour forcer l'affichage.

scanf("%s",&pch[i]);
pch[i] est de type char. Donc il faut mettre "%c".
Ou plus simplement : pch[i]=getchar();

printf(" %c => : %d \n",pch[i],pabc[i]);
pabc est initialisée à 0 grâce à calloc. Il ne contiendra rien d'autre puisque tu ne t'en es pas servi ailleurs. Oubli ?
Par contre ton tableau abc peut être utilisé vu que tu as mis abc[i]=c;

Et enfin n'oublie pas le return 0; après ton getch() final.

Corrige toutes ces erreurs. Si ça ne marche toujours pas, reposte le code corrigé dans une balise code (à droite du bouton sougliné), ainsi que le message d'erreur de la part de ton compilateur.

Cdlt,
2
ghuysmans99 Messages postés 2496 Date d'inscription jeudi 14 juillet 2005 Statut Contributeur Dernière intervention 5 juin 2016 339
20 nov. 2010 à 22:25
Il faut mettre : int main (void) { car main renvoie un int.
Si aucun type de retour n'est précisé, c'est int par défaut ... Mais c'est quand même une pratique dégueulasse, là on est d'accord ;)
0
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 840
20 nov. 2010 à 22:49
i aucun type de retour n'est précisé, c'est int par défaut
Non. Cela était vrai en pré-ansi. Maintenant les normes C89/90 et C99 ce n'est plus autorisé.
0
pochdu12 Messages postés 73 Date d'inscription mardi 11 août 2009 Statut Membre Dernière intervention 19 septembre 2012 21
20 nov. 2010 à 21:34
Bonsoir à toi,

Je n'est pas encore appris ce langage je ne peut donc t'apporter mon aide mais par contre si personne ne te répond sur ce forum ;

Poste donc ton message sur ce site, le site du zéro est constitué d'une communauté de programmeurs et de webmasteurs très expérimentés.

Cordialement Pochdu12.
0