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

Algorithmes et structures de données Discussion :

Exercice : Nombres Troncadivisibles


Sujet :

Algorithmes et structures de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2
    Par défaut Exercice : Nombres Troncadivisibles
    Bonjour tout le monde, je débute dans le langage C et j'ai un petite problème pour résoudre un exercice. Le voici :
    Si vous prenez le nombre 24 et que vous supprimez son chiffre des unités (4), vous obtenez 2, qui divise le nombre de départ 24. Ainsi, un nombre, tel que, si on supprime son chiffre des unités, alors le nouveau nombre formé des chiffres restants divise le nombre de départ, est dit troncadivisible.
    Ecrire un algorithme qui affiche la liste des nombres troncadivisibles inférieurs ou égaux à 2008. Plus donner le langage C.

    Voila, donc si vous pouviez m'aider je vous en remercie d'avance.

  2. #2
    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
    Le bon forum pour poser ta question est celui dédié aux algorithmes: http://www.developpez.net/forums/forumdisplay.php?f=60.

    Si tu as une question précise sur l'implantation de l'algorithme que tu auras développé en langage C, n'hésite pas à poser des questions précises.

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

    +

  3. #3
    Expert confirmé
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    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 245
    Par défaut
    C'est une question facile, bien qu'on puisse sûrement faire mieux en passant 5h à réfléchir (j'exagère un peu), un simple test de tous les nombres de 10 à 2008 suffit ici (ça ne prendra que quelques microsecondes de toutes façon...) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Pour i=1 à 2008
      Si i divisible par (i/10)
        Afficher i
      FinSi
    FinPour
    Avec un test divisiblePar, qui peut-être implémenté à l'aide du modulo en C, par exemple. (i/10) est bien sûr le résultat de la division "entière" (division euclidienne).

    En Haskell ça donnerait :
    Code Haskell : Sélectionner tout - Visualiser dans une fenêtre à part
    filter (\i->(i `mod` (i `div` 10)) == 0) $ [10..2008]

    Néanmoins, il faut remarquer que tous les nombres truncadivisibles au-dessus de 100 sont tous ceux qui finissent par 0 (forcément), tu es sûr que tu ne t'es pas trompé sur la définition ?

    --
    Jedaï

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2
    Par défaut
    je comprend pas ce que tu as écrit, car moi je travaille avec le logiciel labwindows, donc en langage C

  5. #5
    Expert confirmé
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    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 245
    Par défaut
    Citation Envoyé par tchaobino Voir le message
    je comprend pas ce que tu as écrit, car moi je travaille avec le logiciel labwindows, donc en langage C
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Pour i=1 à 2008
      Si i divisible par (i/10)
        Afficher i
      FinSi
    FinPour
    Et en français, tu travailles en français ?
    La version Haskell n'était là qu'en guise de bonus, le pseudo-code ci-dessus est directement traduisible en C, je t'ai même indiqué comment implémenter le "divisible par" en C...

    --
    Jedaï

  6. #6
    Membre chevronné

    Inscrit en
    Août 2007
    Messages
    302
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 302
    Par défaut
    Dans le cas ou le nombre de chiffres est deux (ie n = a0+a1*10, ai appartient a N et 0 <= a0 <= 9, 1 <= a1 <= 9)

    on s'interresse au rapport:

    (a0+a1*10)/a1 = a0/a1 + 10 est entier <=> a0/a1 est entier <=> a0 = k*a1, k appartient a N.

    donc la strategie trivialle pour les nombres de 10 a 99 est de faire qqch du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    pour a1 = 1 -> 9
       pour k = 0 -> 9
          si k * a1 > 10 break
          sinon a0 = a1 * k, print (a1, a0)
       fin pour
    fin pour
    les nombres plus grands que 99 ont deja ete discutes.

    Voila qui permettera de sauver quelques iterations,

    Salutations,


    Gregoire

Discussions similaires

  1. Réponses: 2
    Dernier message: 23/05/2011, 21h47
  2. Réponses: 9
    Dernier message: 05/04/2009, 03h00
  3. [Exercice] Afficher tous les nombres
    Par zlatino dans le forum Pascal
    Réponses: 7
    Dernier message: 05/03/2009, 19h42
  4. Exercice pour débutant : afficher nombres de 0 à 9
    Par gadour14 dans le forum x86 16-bits
    Réponses: 4
    Dernier message: 19/02/2009, 21h07

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