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 :

Problème de variable (grande taille)


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 106
    Par défaut Problème de variable (grande taille)
    Bonjour à tous, je souhaite réserver un espace pour une variable très grande.
    J'utilise DEVCPP je code en C.

    1° je souhaite stocker une variable de l'ordre de : 3000000000000 (13digits)
    2° Je souhaite l'afficher.

    Merci de votre aider, bonne soirée à tous.

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    double Valeur = 3000000000000.0 ;
     
     
    printf ("Valeur : %g \n",Valeur);

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 106
    Par défaut
    désolé ceci ne me convient pas, j ai besoin d'afficher la valeur réelle, de tout afficher. Je souhaite travailler avec la forme non scientifique du nombre

    Merci a toi

  4. #4
    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 jack_x4 Voir le message
    désolé ceci ne me convient pas, j ai besoin d'afficher la valeur réelle, de tout afficher. Je souhaite travailler avec la forme non scientifique du nombre

    Merci a toi
    Tu peux utiliser la bibliothèque GMP qui est faite pour travailler avec les grands entiers: http://gmplib.org/

    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++

    +

  5. #5
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 962
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 962
    Par défaut
    Gio,

    S'il s'agir de valeurs entières, un int de size = 8 octets suffira (18 à 19 digits)

    Le type exact dépend de ton compilateur.

    Sinon, si la solution proposée par souviron34 ne te convient pas uniquement pour un problème d'affichage, il suffit de le régler.

    Sinon, il faudra t'orienter vers les bibliothèques multi-précision GMP par exemple.

  6. #6
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par jack_x4 Voir le message
    désolé ceci ne me convient pas, j ai besoin d'afficher la valeur réelle, de tout afficher. Je souhaite travailler avec la forme non scientifique du nombre

    Merci a toi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    double Valeur = 3000000000000.0 ;
     
     
    printf ("Valeur : %13.0lf \n",Valeur);



    Note : mais ça marche aussi avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    float Valeur = 3000000000000.0 ;
     
     
    printf ("Valeur : %13.0f \n",Valeur);

  7. #7
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 962
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 962
    Par défaut
    Fae,
    Citation Envoyé par souviron34 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    double Valeur = 3000000000000.0 ;
     
     
    printf ("Valeur : %13.0lf \n",Valeur);



    Note : mais ça marche aussi avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    float Valeur = 3000000000000.0 ;
     
     
    printf ("Valeur : %13.0f \n",Valeur);
    Oui, mais si valeur = 3000000000001.0, alors on dépasse le nombre de digits valides pour un float (ça marche avec 3000000000000.0 parce qu'en fait un seul digit significatif est utilisé).

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 106
    Par défaut
    Oh my god ! vous êtes des pros !

    Merci pour toutes vos réponses! Je peux avancer dans mon programme!

    Un grand merci

  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 jack_x4 Voir le message
    J'utilise DEVCPP je code en C.

    1° je souhaite stocker une variable de l'ordre de : 3000000000000 (13digits)
    2° Je souhaite l'afficher.
    En C90, le type entier le plus grand que supporte le C est unsigned long. Sa plage garantie va de 0 à ULONG_MAX, soit, sur ma plateforme et la tienne (Windows/MinGW) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    0 a 4294967295
     
    Press ENTER to continue.
    avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    #include <stdio.h>
    #include <limits.h>
     
    int main (void)
    {
       printf ("0 a %lu\n", ULONG_MAX);
       return 0;
    }
    C'est évidemment insuffisant pour ce que tu demandes.

    En C99, la valeur est plus grande, mais malheureusement, Microsoft ne supportant pas C99, il faut ruser pour l'utiliser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    0 a 18446744073709551615
    Press ENTER to continue.
    avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    #include <stdio.h>
    #include <limits.h>
     
    #ifdef WIN32
    #define LL "I64"
    #else
    #define LL "ll"
    #endif
     
    int main (void)
    {
       unsigned long long max = ULLONG_MAX;
       printf ("0 a %"LL"u\n", max);
       return 0;
    }
    Ca devrait convenir à tes besoins.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    #include <stdio.h>
     
    #ifdef WIN32
    #define LL "I64"
    #else
    #define LL "I64"
    #define LL "ll"
    #endif
     
    int main (void)
    {
       unsigned long long n = 3000000000000;
       printf ("n = %" LL "u\n", n);
     
       return 0;
    }
    donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    n = 3000000000000
     
    Press ENTER to continue.

  10. #10
    Membre chevronné Avatar de dapounet
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2007
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2007
    Messages : 469
    Par défaut
    Pour Visual Studio ce code a l'air de fonctionner chez moi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #include <limits.h>
    #include <stdio.h>
     
     
    int main (void)
    {
       long long ll = (long long)LONG_MAX + 1;
     
       printf ("%lld\n", ll);
       return 0;
    }
    Il donne le même résultat que celui-là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #include <limits.h>
    #include <stdio.h>
     
     
    int main (void)
    {
       _int64 ll = (_int64)LONG_MAX + 1;
     
       printf ("%I64d\n", ll);
       return 0;
    }

  11. #11
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 392
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 392
    Par défaut
    Cela dépend de la version de la CRT: Le spécificateur "ll" n'est géré qu'à partir de Visual 2005.

    Et même Visual 2008 ne gère pas des spécificateurs C99 comme "z" (il utilise "I" à la place)...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Réponses: 9
    Dernier message: 11/05/2012, 12h25
  2. Réponses: 22
    Dernier message: 20/01/2009, 13h57
  3. Réponses: 5
    Dernier message: 21/11/2006, 16h24
  4. problème de conversion de très très grande taille !
    Par Conficius dans le forum Langage
    Réponses: 2
    Dernier message: 05/11/2005, 22h14
  5. Réponses: 6
    Dernier message: 19/10/2004, 13h46

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