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 faire le modulo d'un double?


Sujet :

C

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    114
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 114
    Points : 71
    Points
    71
    Par défaut Comment faire le modulo d'un double?
    J'ai un variable double contenant une valeur (positive et sans virgule).
    J'ai pris un double car ma valeur doit tenir sur 8 octets.
    Par contre je voudrais faire un modulo sur ma variable double mais je ne peux pas (avec %).
    Comment faire?
    Il existe une fonction modulo pour les double ou pas?

  2. #2
    Membre expérimenté
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Points : 1 729
    Points
    1 729
    Par défaut
    Salut, je pense pas qu'on puisse faire modulo sur les doubles, a mon avis, les double dans ce cas ci seraient convertis en entiers d'abord
    Si c'est juste pour l'aspect 8octets que tu prends un double, essaye le long long

  3. #3
    Expert éminent sénior
    Avatar de Skyounet
    Homme Profil pro
    Software Engineer
    Inscrit en
    Mars 2005
    Messages
    6 380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Software Engineer
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 6 380
    Points : 13 380
    Points
    13 380
    Par défaut
    Citation Envoyé par Kr00pS
    Bah avec un malloc ça va pas ?

    int *modulo = malloc(8);

    if (modulo != NULL)
    {
    ...
    }

    La si je ne m'abuse tu as un tableau de 2 int (sur une architecture où un int vaut 4 octets)

  4. #4
    Membre éclairé Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Points : 858
    Points
    858
    Par défaut
    Citation Envoyé par Kr00pS
    Bah avec un malloc ça va pas ?

    int *modulo = malloc(8);

    if (modulo != NULL)
    {
    ...
    }
    Je ne vois pas trop le rapport avec le l'opération modulo !!!

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    114
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 114
    Points : 71
    Points
    71
    Par défaut
    c'est quoi le long long?
    C'est un entier sur 8 octets?

  6. #6
    Membre expérimenté
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Points : 1 729
    Points
    1 729
    Par défaut
    Oui mais c'est pas portable je crois (c'est pas toutes les architectures qui le supportent)

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    114
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 114
    Points : 71
    Points
    71
    Par défaut
    Bin sa compile pas avec visual c++.
    Dommage.

  8. #8
    Membre habitué
    Inscrit en
    Octobre 2005
    Messages
    141
    Détails du profil
    Informations personnelles :
    Âge : 32

    Informations forums :
    Inscription : Octobre 2005
    Messages : 141
    Points : 135
    Points
    135
    Par défaut
    C'est la norme C99 les long long non ?

  9. #9
    Membre expérimenté
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Points : 1 729
    Points
    1 729
    Par défaut
    Oué je crois Kr00ps

    guintolli, note que meme en math, vouloir faire le modulo d'un flottant ça n'a pas de sens, car c'est le reste de la division entiere

  10. #10
    Expert éminent sénior
    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
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par guintolli
    Il existe une fonction modulo pour les double ou pas?
    fmod()

  11. #11
    Membre expérimenté
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Points : 1 729
    Points
    1 729
    Par défaut
    J'ai rien dit alors

  12. #12
    Membre habitué
    Inscrit en
    Octobre 2005
    Messages
    141
    Détails du profil
    Informations personnelles :
    Âge : 32

    Informations forums :
    Inscription : Octobre 2005
    Messages : 141
    Points : 135
    Points
    135
    Par défaut
    Bah c'est compréhensible si c'est Visual C++ 6 (il date de 98 je crois).

  13. #13
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    114
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 114
    Points : 71
    Points
    71
    Par défaut
    Merci beaucoup.
    Fmod() marche très bien.

    Sinon j'avai aussi la solution:
    var - 64*(var/64)

    Mais fmod(var,64) est quand même plus pratique.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Comment faire : New Dictionary(Of Integer(), Double)
    Par Gualino dans le forum VB.NET
    Réponses: 8
    Dernier message: 31/10/2011, 18h49
  2. [C#] Comment faire un double panel
    Par joujoukinder dans le forum Windows Forms
    Réponses: 4
    Dernier message: 15/07/2006, 07h11
  3. [VB.NET] DataGridView à double entrée: comment faire?
    Par BillyboyK dans le forum Windows Forms
    Réponses: 7
    Dernier message: 06/04/2006, 09h06
  4. [Conversion]Comment faire pour couper un Double trop long?
    Par dessinateurttuyen dans le forum Général Java
    Réponses: 1
    Dernier message: 13/11/2005, 02h22

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