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 :

dépacement capacité (division euclidienne)


Sujet :

C++

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 102
    Points : 53
    Points
    53
    Par défaut dépacement capacité (division euclidienne)
    Bonsoir tout le monde, voilà j'ai un soucis de dépassement de capacité et je ne sais comment le résoudre.

    j'ai trois entier x, y ,z et j'ai besoin de récupérer le quotient et le reste (division euclidienne) de la division de (x*y) par z, le soucis et que x*y fait un dépassement de capacité . j'ai réussi à récupérer le quotient :

    le soucis c'est que que je sais pas comment récupèrer le reste (de la division euclidienne)

    merci d'avance

    yann

  2. #2
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    Le reste, c'est pas (x*y) - (q*z)
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  3. #3
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 942
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 942
    Points : 5 654
    Points
    5 654
    Par défaut
    Hai,

    en passant par un type entier plus grand ?

    64 bits au lieu de 32 (probable avec le int)
    Si les cons volaient, il ferait nuit à midi.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 102
    Points : 53
    Points
    53
    Par défaut
    Citation Envoyé par ram-0000 Voir le message
    Le reste, c'est pas (x*y) - (q*z)
    si si le reste c'est bien ça mais (x*y) (avec mes jeux de test) provoque un dépassement de capacité.

    je vais re essayer avec un long int, mais il me semble que j'ai déjà essayé

  5. #5
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    essaye plutôt avec "long long int" ou "__int64" qui sont sur 64 bits
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  6. #6
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Points : 13 017
    Points
    13 017
    Par défaut
    x=a1*z+b1
    y=a2*z+b2
    x*y = (a1*z+b1)*(a2*z+b2)
    = a1*a2*z + a1*b2*z + b1*a2*z + b1*b2
    = (a1*a2 + a1*b2 + b1*a2) z + b1*b2
    b1*b2 = c*z + d
    x*y = (a1*a2 + a1*b2 + b1*a2) z + c*z + d
    = (a1*a2 + a1*b2 + b1*a2 + c) z + d
    Donc
    -> quotient(x*y/z) = quotient(x/z)*quotient(y/z) + quotient(x/z)*reste(y/z) + quotient(y/z)*reste(x/z) + quotien(reste(x/z)*reste(y/z))
    -> reste(x*y/z) = reste(reste(x/z)*reste(y/z))
    Si je ne me suis pas trompé dans le développement mathématique, tu dois pouvoir calculer tes éléments sans passer par un type plus grand.

Discussions similaires

  1. Division euclidienne de polynomes
    Par elishac dans le forum Caml
    Réponses: 3
    Dernier message: 02/06/2009, 00h16
  2. Division euclidienne
    Par cixiii dans le forum R
    Réponses: 1
    Dernier message: 24/04/2008, 18h02
  3. Division euclidienne polynomiale (avec modulos)
    Par Batoche dans le forum Mathématiques
    Réponses: 5
    Dernier message: 18/12/2006, 14h03
  4. division euclidienne de polynôme
    Par gronaze dans le forum Mathématiques
    Réponses: 1
    Dernier message: 29/06/2006, 20h53

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