Probléme en c
star
-
lami20j Messages postés 21331 Date d'inscription Statut Modérateur, Contributeur sécurité Dernière intervention -
lami20j Messages postés 21331 Date d'inscription Statut Modérateur, Contributeur sécurité Dernière intervention -
Bonjour,
j'essaye de faire un programme en C qui demande 3 couleur et qui affiche la valeur de la resistance qui les porte.
Le programme affiche aussi un message précisant si la valeurs de la résistance est conforme a la serie E24.
Exemple d'exécution de ce programme:
donner la couleur de l'anneau 1:rouge
donner la couleur de l'anneau 2:marron
donner la couleur de l'anneau 3:jaune
210 k ohm ne fait pas partie de la serie E24
j'ai besoin de vous aides
merci
j'essaye de faire un programme en C qui demande 3 couleur et qui affiche la valeur de la resistance qui les porte.
Le programme affiche aussi un message précisant si la valeurs de la résistance est conforme a la serie E24.
Exemple d'exécution de ce programme:
donner la couleur de l'anneau 1:rouge
donner la couleur de l'anneau 2:marron
donner la couleur de l'anneau 3:jaune
210 k ohm ne fait pas partie de la serie E24
j'ai besoin de vous aides
merci
3 réponses
Bonjour,
J'ai déjà tapé ce début de code à améliorer :
J'ai déjà tapé ce début de code à améliorer :
#include <stdio.h> #include <tchar.h> #include <math.h> #include <ctype.h> void Affiche_Couleurs_No() { printf("Noir : 0\n"); printf("Magenta : 1\n"); printf("Rouge : 2\n"); printf("Orange : 3\n"); printf("Jaune : 4\n"); printf("Vert : 5\n"); printf("Bleu : 6\n"); printf("Violet : 7\n"); printf("Gris : 8\n"); printf("Blanc : 9\n"); } char *substr(const char *s, int deb, int len) { char *str = calloc (len + 1, sizeof(char)); strncpy (str,deb + s,len); return str; } int main() { char Couleur_1[2]; char Couleur_2[2]; char Couleur_3[2]; char Res_Ohms_Char_Dig_2[3]; int Res_Ohms_Int_Dig = 0; printf(" -----------------------------------------------------------------------------------------------\n"); printf(" ------------------------------ CALCUL RESISTANCE --------------\n"); printf(" -----------------------------------------------------------------------------------------------\n\n"); Affiche_Couleurs_No(); printf("\n > Entrez la 1ere couleur : "); scanf("%s", &Couleur_1); printf(" > Entrez la 2eme couleur : "); scanf("%s", &Couleur_2); printf(" > Entrez la 3eme couleur : "); scanf("%s", &Couleur_3); strcpy(Res_Ohms_Char_Dig_2, substr(&Couleur_1,0,1)); strcat(Res_Ohms_Char_Dig_2, substr(&Couleur_2,0,1)); Res_Ohms_Int_Dig = atoi(Res_Ohms_Char_Dig_2); Res_Ohms_Int_Dig = Res_Ohms_Int_Dig * pow(10,atoi(Couleur_3)); printf(" > Resistance : %d Ohms", Res_Ohms_Int_Dig); return(0); }
Salut,
scanf("%s", &Couleur_1);
Couleur_1 est un une chaîne de caractère, pas besoin de &, etc.
substr c'est quoi?
scanf("%s", &Couleur_1);
Couleur_1 est un une chaîne de caractère, pas besoin de &, etc.
substr c'est quoi?
Ce qui a de bien c'est qu'on est pas perdu avec les élèves :-)
http://www.commentcamarche.net/forum/affich 11519691 un bon exercice programmation
Bon mais on a progressé, là au moins on sent qu'il y a du progret et un début de travail.
Sinon lami20j substr est une fonction qui extrait une sous chaîne et qu'il a réécrit dans son code.
Quelques remarques :
- en C il faut éviter les allocations quand ce n'est pas nécessaire, surtout que là tu n'en as pas besoin et que là tu ne désalloue pas ce que substr a alloué. En l'occurrence une sous chaîne n'est qu'un sous tableau. et là tu pousses le vice à n'extraire qu'un caractère... il suffit d'écrire my_str[i] pour extaire le ième char !
- return n'est pas une fonction. Ecris directement "return 0;"
- évite les headers non standards et inutiles comme <tchar.h>.
- pourquoi passer par une chaîne quand un scanf permet de lire directement un entier ???? Surtout si c'est pour faire un atoi derrière ?
Bonne chance
http://www.commentcamarche.net/forum/affich 11519691 un bon exercice programmation
Bon mais on a progressé, là au moins on sent qu'il y a du progret et un début de travail.
Sinon lami20j substr est une fonction qui extrait une sous chaîne et qu'il a réécrit dans son code.
Quelques remarques :
- en C il faut éviter les allocations quand ce n'est pas nécessaire, surtout que là tu n'en as pas besoin et que là tu ne désalloue pas ce que substr a alloué. En l'occurrence une sous chaîne n'est qu'un sous tableau. et là tu pousses le vice à n'extraire qu'un caractère... il suffit d'écrire my_str[i] pour extaire le ième char !
- return n'est pas une fonction. Ecris directement "return 0;"
- évite les headers non standards et inutiles comme <tchar.h>.
- pourquoi passer par une chaîne quand un scanf permet de lire directement un entier ???? Surtout si c'est pour faire un atoi derrière ?
int x; do{ printf("saisissez un entier compris entre 0 et 9\n"); } while(!scanf("%d",&x) || x < 0 || x > 9);
Bonne chance