IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

comment mettre des exposants?


Sujet :

C

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 8
    Par défaut comment mettre des exposants?
    re salut

    en fait j'ai besoin de mon code de prendre la racine carré d'une variable je pense passer par exposant (1/2) mais je ne sais pas comment ecrire l'exposant. je suis sous dev C et j'ai essayer:
    et aussi avec un e minuscule mais g une erreur qui me dit :
    16 D:\Mes documents\carole\main4.c syntax error before "E"
    16 D:\Mes documents\carole\main4.c syntax error before ')' token

    merci d'avance pour votre aide

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 299
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    pow(x,2.)
    pow(x,0.5)
    n'oublie pas de mettre #include<math.h> et lors de l'édition des liens de mettre -lm

  3. #3
    Membre Expert Avatar de zooro
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2006
    Messages
    921
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2006
    Messages : 921
    Par défaut
    Essaie sqrt :
    La fonction sqrt() renvoie la racine carrée non-négative de x. Elle échoue et positionne errno a EDOM, si x est négatif.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    #include <math.h>
    double sqrt (double x);
    float sqrt (float x);
    long double sqrt (long double x);

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 299
    Par défaut
    (delta)E(1/2)
    attention !!!!!

    c'est une division d'entier. En revanche

    division de double

  5. #5
    Membre Expert Avatar de zooro
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2006
    Messages
    921
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2006
    Messages : 921
    Par défaut
    Citation Envoyé par salseropom
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    pow(x,2.)
    pow(x,0.5)
    n'oublie pas de mettre #include<math.h> et lors de l'édition des liens de mettre -lm
    man pow :
    La fonction pow() renvoie la valeur de x élevé à la puissance y.

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 299
    Par défaut
    man pow :
    Citation:
    La fonction pow() renvoie la valeur de x élevé à la puissance y.
    oui je sais, mais pow(x,0.5) == sqrt(x)
    et j'avais rajouté un exemple pour faire x^2 : pow(x,2.) (même s'il vaut mieux écrire x*x)

  7. #7
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Par défaut
    Citation Envoyé par salseropom
    En général, on évite de comparer des expressions de type double à cause des erreurs d'arrondi.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 8
    Par défaut
    une autre question svp....
    si je veux faire la division de deux double et que je veux le resultat exact comment je fais???
    j'ai essayer avec "/" mais ça me retourne 0 alors que j suis senser avoir 4/2=2 il me semble....



    en fait je crois que ce n'est pas ça le probleme, dsl je vais faire un nouveau sujet pour expliquer...

  9. #9
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par carole8
    une autre question svp....
    si je veux faire la division de deux double et que je veux le resultat exact comment je fais???
    j'ai essayer avec "/" mais ça me retourne 0 alors que j suis senser avoir 4/2=2 il me semble....
    double et exact ne sont pas des mots qui vont ensemble. La représentation interne des doubles quasiment toujours une approximation de la valeur attendue.

    Ensuite, il ne faut pas se tromper dans les formats d'affichage. Pour char, short et int, c'est "%d" (décimal), pour long, c'est "%ld", pour float et double, c'est "%f" (décimal) ou "%e" et "%g" (scientifique).

  10. #10
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Par défaut
    Citation Envoyé par carole8
    une autre question svp....
    si je veux faire la division de deux double et que je veux le resultat exact comment je fais???
    j'ai essayer avec "/" mais ça me retourne 0 alors que j suis senser avoir 4/2=2 il me semble....

    en fait je crois que ce n'est pas ça le probleme, dsl je vais faire un nouveau sujet pour expliquer...
    L'expression constante 4/2 est de type int, tandis que 4.0/2 est de type double (il y a conversion de la constante 2 dans le type double).

    Tu n'obtiendra toutefois pas un résultat exacte. En effet, le test 4.0/2.0 == 2.0 peut échouer à cause d'erreurs d'arrondi. Les résultat de l'expression 4.0/2 n'est pas exact de par la nature même des nombres flottants.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  11. #11
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 299
    Par défaut
    pour comparer deux doubles (d1 et d2), il faut faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if(fabs(d1-d2)<=DBL_EPSILON) blabla
    #include<float.h> pour avoir la constante DBL_EPSILON

    si tu fais

    alors tu auras le warning suivant :

    attention : comparing floating point with == or != is unsafe

Discussions similaires

  1. [VS 2005] Comment mettre des pages en relation ?
    Par batosai dans le forum Visual Studio
    Réponses: 6
    Dernier message: 24/04/2006, 17h01
  2. comment mettre des int dans une char??
    Par gronaze dans le forum C
    Réponses: 5
    Dernier message: 21/04/2006, 17h02
  3. Réponses: 10
    Dernier message: 28/03/2006, 15h10
  4. Comment mettre des couleurs a printf ( )
    Par damien42 dans le forum C
    Réponses: 27
    Dernier message: 31/03/2005, 23h10
  5. Comment mettre des lignes de couleur dans une TCheckListBox ?
    Par Isa31 dans le forum Composants VCL
    Réponses: 9
    Dernier message: 31/03/2005, 08h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo