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

Mathématiques Discussion :

PGCD de plusieurs nombres


Sujet :

Mathématiques

  1. #1
    Membre habitué
    Avatar de barthelv
    Inscrit en
    Mars 2003
    Messages
    267
    Détails du profil
    Informations forums :
    Inscription : Mars 2003
    Messages : 267
    Points : 126
    Points
    126
    Par défaut PGCD de plusieurs nombres
    Bonjour,

    J'ai trouvé plusieurs façons de coder le PGCD de deux nombres sur le forum C++:

    http://www.developpez.net/forums/vie...highlight=pgcd

    Le problème est que moi je veux calculer le PGCD de plusieurs nombres et pas seulement de deux. Du coup, j'hésite sur la méthode à appliquer. Question complexité, je pense qu'il doit existerun algo meilleur que de prendre les PGCD de chaque combinaison, ce qui risque d'être fastidieux...

  2. #2
    Membre habitué
    Avatar de barthelv
    Inscrit en
    Mars 2003
    Messages
    267
    Détails du profil
    Informations forums :
    Inscription : Mars 2003
    Messages : 267
    Points : 126
    Points
    126
    Par défaut Formule du pgcd....
    Je viens de trouver cette formule, est-elle la plus optimisée, ou puis-je trouver mieux?

    Le P.G.C.D. de trois entiers peut être calculé par :

    pgcd (a,b,c) =pgcd(pgcd(a,b),c) = pgcd (a, pgcd (b, c))

  3. #3
    Rédacteur

    Avatar de khayyam90
    Homme Profil pro
    Architecte de système d’information
    Inscrit en
    Janvier 2004
    Messages
    10 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Architecte de système d’information

    Informations forums :
    Inscription : Janvier 2004
    Messages : 10 369
    Points : 40 164
    Points
    40 164
    Par défaut
    une possibilité pour calculer le pgcd de plusieurs nombres est de faire comme quand on veut le calculer à la main : tu décomposes tous tes nombres en produit de facteurs premiers, le pgcd sera le produit de ce que tu trouveras en commun sur toutes tes décompositions.

  4. #4
    Membre habitué
    Avatar de barthelv
    Inscrit en
    Mars 2003
    Messages
    267
    Détails du profil
    Informations forums :
    Inscription : Mars 2003
    Messages : 267
    Points : 126
    Points
    126
    Par défaut
    Citation Envoyé par khayyam90
    une possibilité pour calculer le pgcd de plusieurs nombres est de faire comme quand on veut le calculer à la main : tu décomposes tous tes nombres en produit de facteurs premiers, le pgcd sera le produit de ce que tu trouveras en commun sur toutes tes décompositions.
    Je ne pense pas que cela soit optimisé...

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Août 2003
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2003
    Messages : 247
    Points : 276
    Points
    276
    Par défaut
    Citation Envoyé par barthelv
    Citation Envoyé par khayyam90
    une possibilité pour calculer le pgcd de plusieurs nombres est de faire comme quand on veut le calculer à la main : tu décomposes tous tes nombres en produit de facteurs premiers, le pgcd sera le produit de ce que tu trouveras en commun sur toutes tes décompositions.
    Je ne pense pas que cela soit optimisé...
    C'est même la pire des méthodes...

    Pour calculer, le PGCD, le meilleur rapport simplicité/efficacité est sans doute l'algorithme d'Euclide. Pour un calcul à la main, on préfèrera aussi cette méthode. ;-)

  6. #6
    Nouveau membre du Club
    Inscrit en
    Juin 2002
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 58
    Points : 35
    Points
    35
    Par défaut
    SAlut,

    Si c'est pour ton pobleme de signal, pense deja à retirer les valeurs boublonsGCD(a,a)=a
    A+
    il vaut mieux mobiliser son intelligence sur des conneries que mobiliser sa connerie sur des choses intelligentes (devise Shadok)

  7. #7
    Membre averti
    Avatar de JHelp
    Inscrit en
    Octobre 2002
    Messages
    185
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 185
    Points : 444
    Points
    444
    Par défaut
    Petite idée, à voir si ca te convient.

    tab : tableau des entiers dont on cherchent le pgcd
    nb : nombe d'éléments du tableau
    E(reel)->entier : partie entiére
    sqrt(reel)->reel : racine carré

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    PGCD(tab, nb)
     | max <- E(sqrt(tab[0]) + 1;
     | Pour(i=1; i<nb; i++)
     |  |  | m <- E(sqrt(tab[i])) + 1
     |  | Si(max < m)
     |  |  | max = m
     |  | Fin-Si
     | Fin-Pour
     | rang <- 2
     | reponse <- 1
     | Tant-Que(rang <= max)
     |  | n <- 0
     |  | Pour(i=0; i<nb; i++)
     |  |  | Si(tab[i] MOD rang == 0)
     |  |  |  | n ++
     |  |  |  | tab[i] <- tab[i] DIV rang
     |  |  | Fin-Si
     |  | Fin-pour
     |  | Si(n == nb)
     |  |  | reponse <- reponse * rang
     |  |  | max <- max DIV E(sqrt(rang))
     |  | Sinon Si(n == 0)
     |  |  | rang ++
     |  | Sinon
     |  |  | max <- E(sqrt(tab[0]) + 1;
     |  |  | Pour(i=1; i<nb; i++)
     |  |  |  | m <- E(sqrt(tab[i])) + 1
     |  |  |  | Si(max < m)
     |  |  |  |  | max = m
     |  |  |  | Fin-Si 
     |  |  | Fin-Pour
     |  | Fin-Si
     | Fin-Tant-Que
     | Renvoie reponse
    Fin
    JHelp
    Pour avoir une réponse efficace :
    1) Soyez précis dans vos questions
    2) Choisssez bien votre forum
    3) Consultez la FAQ et la doc avant

  8. #8
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Salut
    Je suis d'accord avec
    Citation Envoyé par Blawk
    Pour calculer, le PGCD, le meilleur rapport simplicité/efficacité est sans doute l'algorithme d'Euclide. Pour un calcul à la main, on préfèrera aussi cette méthode.
    J'ajouterai qu'il peut être intéressant de commencer par les deux plus petits nombres.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 22/11/2018, 07h11
  2. Réponses: 24
    Dernier message: 24/06/2010, 11h48
  3. [WD12] Calcul du PGCD de deux nombres
    Par orditosh dans le forum WinDev
    Réponses: 10
    Dernier message: 15/04/2009, 17h39
  4. recherche avec plusieurs nombre
    Par osia1 dans le forum VBA Access
    Réponses: 2
    Dernier message: 17/04/2008, 15h52
  5. Algorithme permettant de calculer le PGCD de deux nombres
    Par zeyd dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 25/11/2005, 20h37

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