1. #1
    Membre à l'essai
    Inscrit en
    juin 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : juin 2009
    Messages : 18
    Points : 24
    Points
    24

    Par défaut les nombres d'AMSTRONG.

    salut tout le monde,

    pouvez vous m'aider a concevoir un algorithme qui permet d'afficher tous les nombres d'AMSTRONG inférieurs a un entier naturel donnée. en utilisantune fonction qui fournit le cube d'un chiffre et une fonction qui vérifie si un nombre donnée est un nombre d'AMSTRONG.

    SVP donner moi une idée sur les nombres d'AMSTRONG.

    et merci d'avance.

  2. #2
    Membre confirmé

    Homme Profil pro
    Chercheur d'emploi
    Inscrit en
    octobre 2008
    Messages
    367
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chercheur d'emploi

    Informations forums :
    Inscription : octobre 2008
    Messages : 367
    Points : 646
    Points
    646

    Par défaut

    Salut,
    Citation Envoyé par noussa17 Voir le message
    SVP donner moi une idée sur les nombres d'AMSTRONG.
    Citation Envoyé par Wikipédia
    Un nombre d'Armstrong est un nombre dont la somme des cubes des chiffres le composant vaut ce nombre.

    Exemple : 371 = 3^3 + 7^3 + 1^3

    Les nombres d'Armstrong à trois chiffres sont : 0, 1, 153, 370, 371 et 407.
    Citation Envoyé par noussa17 Voir le message
    pouvez vous m'aider a concevoir un algorithme qui permet d'afficher tous les nombres d'AMSTRONG inférieurs a un entier naturel donnée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Pour i de 1 à n faire
      a <-- 0;
      q <-- i;
      Tant que n différent de 0 faire
        r <-- reste de la division de q par 10;
        q <-- quotient de la division de q par 10;
        a <-- a + r³;
      Fin Tant que
      Si a = i alors
        écrire(i);
      Fin Si
    Fin Pour
    --
    Wachter
    Code parrain certification Voltaire : NTMPH759

  3. #3
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    avril 2003
    Messages
    6 220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : avril 2003
    Messages : 6 220
    Points : 8 448
    Points
    8 448

    Par défaut

    On peut néanmoins faire mieux avec un peu d'astuce et en partant des combinaisons de chiffres plutôt que de tester chaque nombre dans l'ordre.

    (NB: Les nombres d'Armstrong ne sont normalement pas forcément la somme des cubes de leurs chiffres mais plutôt la somme de leurs chiffres élevés au nombre de chiffres, par exemple 1634 = 1^4 + 6^4 + 3^4 + 4^4 est un nombre d'Armstrong (aussi appelé nombre narcissiques), je n'ai pas trouvé de références limitant l'usage du terme "nombres d'Armstrong" au cas 3, sauf dans l'article lapidaire de la Wikipédia française)

    --
    Jedaï

  4. #4
    Inactif
    Avatar de Mac LAK
    Profil pro
    Inscrit en
    octobre 2004
    Messages
    3 893
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : octobre 2004
    Messages : 3 893
    Points : 4 872
    Points
    4 872

    Par défaut

    Citation Envoyé par Jedai Voir le message
    sauf dans l'article lapidaire de la Wikipédia française
    Idem. Article Wikipédia modifié, d'ailleurs.
    Mac LAK.
    ___________________________________________________
    Ne prenez pas la vie trop au sérieux, de toutes façons, vous n'en sortirez pas vivant.

    Sources et composants Delphi sur mon site, L'antre du Lak.
    Pas de question technique par MP : posez-la dans un nouveau sujet, sur le forum adéquat.

    Rejoignez-nous sur : Serveur de fichiers [NAS] Le Tableau de bord projets Le groupe de travail ICMO

  5. #5
    Membre éclairé
    Avatar de bombseb
    Inscrit en
    juillet 2005
    Messages
    562
    Détails du profil
    Informations forums :
    Inscription : juillet 2005
    Messages : 562
    Points : 854
    Points
    854

    Par défaut

    Un nombre d'Armstrong est un nombre dont la somme des cubes des chiffres le composant vaut ce nombre.

    Exemple : 371 = 3^3 + 7^3 + 1^3

    Les nombres d'Armstrong à trois chiffres sont : 0, 1, 153, 370, 371 et 407.
    j'ai beau refaire cette opération 3^3 + 7^3 + 1^3 : je ne trouve pas 371
    (pareil pour 370) ou alors il y a un truc que j'ai pas compris

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    février 2004
    Messages
    19 743
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : février 2004
    Messages : 19 743
    Points : 39 825
    Points
    39 825

    Par défaut

    Dans la plupart des langages l'opérateur "^" ne veut pas dire "puissance" mais "XOR" (OU exclusif)... donc :

    3^3 + 7^3 + 1^3
    = 3 XOR 3 + 7 XOR 3 + 1 XOR 3
    = 0 + 4 + 2
    = 6

    Pour mettre un nombre x au cube, utilise x*x*x

    3*3*3 + 7*7*7 + 1*1*1
    = 27 + 343 + 1
    = 371

  7. #7
    Responsable Modération
    Avatar de Obsidian
    Homme Profil pro
    Chercheur d'emploi
    Inscrit en
    septembre 2007
    Messages
    6 572
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur d'emploi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : septembre 2007
    Messages : 6 572
    Points : 20 083
    Points
    20 083

    Par défaut

    Juste pour info, un certain nombre de langages, y compris celui de gnuplot mais à l'exception des dérivés du C, proposent l'opérateur ** pour élever à la puissance n.

Discussions similaires

  1. les NOMBRES D'AMSTRONG
    Par noussa17 dans le forum Débuter
    Réponses: 3
    Dernier message: 15/12/2009, 17h02
  2. [MS-DOS] Compter les nombres de jours entre deux dates diffé
    Par Furius dans le forum Scripts/Batch
    Réponses: 4
    Dernier message: 19/02/2006, 13h33
  3. Réponses: 24
    Dernier message: 27/09/2005, 21h16
  4. Les nombres complexe et delphi
    Par wikers dans le forum Langage
    Réponses: 3
    Dernier message: 04/08/2005, 11h47

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