Discussion:Tours de Hanoï
Je ne vois pas trop l'intérêt de multiplier les traductions dans différents langages de programmation de l'algorithme des tours de Hanoï, si ce n'est pour faire du remplissage. Il me paraîtrait beaucoup plus opportun de donner un seul exemple de programme récursif, dans un seul langage. Theon 29 avril 2006 à 17:45 (CEST)
Animation fausse !
[modifier le code]Bonjour. Cet article est complétée par une image animée représentant une soi-disante résolution du problème :
Seulement, la réponse donnée est erronée ! Dans cette animation n'est en effet pas respectée la deuxième partie de la première règle :
- on ne peut placer un disque que sur un autre disque plus grand que lui [...]
Ce qui vaut également pour une "traversée" de la gauche vers la droite : la véritable solution est en vérité un peu plus longue. J'ai donc supprimé cette image, je vous laisse en mettre une autre, correcte, si le coeur vous en dit. Lazuli 27 octobre 2007 à 15:15 (CEST)
- Euh... Je vois pas en quoi l'animation est fausse, c'est exactement comme ça qu'on résoud le problème des Tours de Hanoï. Je ne sais pas d'où vient cette histoire de « traversée », mais en tout cas j'ai toujours vu la solution décrite par l'image pour résoudre le problème. PieRRoMaN 28 octobre 2007 à 01:00 (CEST)
- L'animation est parfaitement correcte. Theon 28 octobre 2007 à 09:28 (CET)
- Ce n'est pas comme ça qu'on me l'a apprise et que je l'ai toujours vu :
- Par exemple, ici, au début, le disque rouge va en position 2, le disque jaune va en position 3 (et passe par dessus le disque rouge, plus petit, c'est ce que j'appelle "traversée"), puis le rouge s'arrête sur le jaune en position 3.
- Dans la version qu'on m'a apprise, le disque rouge va en position 3, puis le jaune en position 2, puis le rouge retourne en position 1, le jaune se déplace alors en position 3 et le jaune va le rejoindre, et ainsi de suite : c'est plus long, mais de cette manière jamais un disque ne se trouve sur un disque plus petit, même s'il ne s'arrête pas (ce que j'appelais "traversée").
- Ma version me parait la plus proche des règles, mais peut-être existe-il deux versions du même jeu ? L'une plus rapide ou le passage sur un disque plus petit est autorisée s'il ne s'agit pas d'un stationnement, et une autre plus longue où cela est interdit... Dans ce cas, peut-être serait-il bon de mentionner les deux versions dans l'article ?
- Je le laisse à votre jugement : je ne suis pas mathématicienne, loin de là, je n'ai modifié cet article que parce que ma mère, professeure de mathématique, me l'a mentionné comme étant faux. Et c'est effectivement la version "longue" que je viens de décrire qu'elle m'avait apprise dans mon enfance, et qu'elle apprend à ces élèves. Cela dit, il est possible qu'il ne s'agisse pas du tout de la version "officielle", et je ne sais pas vraiment vers quelles sources fiables me tourner pour confirmer ou infirmer ses propos (et je serai bien incapable de dire à laquelle des deux versions se reportent les algorythmes mentionnés dans cet article).
- A vous devoir, donc, et vraiment désolée si ma modification et mon intervention était à tord. Par curiosité, pourriez-vous tout de même me donner une "source" validant votre version ? Cela devrait intéresser ma mère. Merci beaucoup ! Lazuli
- L'animation est parfaitement correcte "ON NE PEUT EMPILER LES DISQUE QUE SUR UN DISQUE PLUS GRAND QUE LUI" est parfaitement respecté dans cet exemple.
- Solution avec la règle des traversées qui constitue un handicap supplémentaire:
- 1)rouge vers 3; 2)jaune vers 2; 3)rouge vers 1; 4)jaune vers 3; 5)rouge vers 3; 6)bleu vers 2; 7)rouge vers 1; 8)jaune vers 2; 9)rouge vers 3; 10)jaune vers 1; 11)rouge vers 1; 12)bleu vers 3; 13)rouge vers 3; 14)jaune vers 2; 15)rouge vers 1; 16)jaune vers 3; 17)rouge vers 3; 18)orange vers 2; 19)rouge vers 1; 20)jaune vers 2; 21)rouge vers 3; 22)jaune vers 1; 23)rouge vers 1; 24)bleu vers 2; 25) rouge vers 3; 26)jaune vers 2; 27)rouge vers 1; 28)jaune vers 3 ;29)rouge vers 3; 30) bleu vers 1; 31)rouge vers 1; 32)jaune vers 2; 33)rouge vers 3; 34)jaune vers 1; 35)rouge vers 1; 36)orange vers 3; 37)rouge vers 3; 38)jaune vers 2; 39)rouge vers 1; 40)jaune vers 3; 41) rouge vers 3; 42)bleu vers 2; 43)rouge vers 1; 44)jaune vers 2; 45)rouge vers 3; 46)jaune vers 1; 47)rouge vers 1; 48)bleu vers 3; 49)rouge vers 3; 50)jaune vers 2; 51)rouge vers 1; 52)jaune vers 3; 53)rouge vers 3. Ouf ! ça y est, maintenant j'ai besoins d'une aspirine parce que ça fais mal de calculer ça de tête. En gros il faut une bonne 50aine de coups alors que la formule nous annonce 15 coups pour 4 disques (cf: animation), perso j'appelle ça de l'acharnement mathématique ou l'art de se mettre des battons dans les roues.
- L'animation est parfaitement correcte. Theon 28 octobre 2007 à 09:28 (CET)
Temps d'éxécution pour 64 anneaux.
[modifier le code]Bonjour, me fiant à ma calculatrice, j'obtiens bien 24 heures/jour * 3600 secondes/heure=86400secondes/jour. Toutefois 2^64/86400 me donne 213.503.982.334.601,291851852, donc, à 2 décimales significatives, 214E12, ou 2,14E14. Je me permets donc de rectifier le 2,18E14 annoncé. En prenant 360 jours par an, j'obtiens de l'ordre de 213503982334601,291851852/360=593.066.617.596,114699588, disons 600 milliards d'années, ou quarante fois l'âge estimé de l'univers (15 milliards d'années), ce qui contredit les plusieurs trilliards d'années annoncés. — Le message qui précède, non signé, a été déposé par RudeWolf (discuter)
- En effet j'avais pris 84600 au lieu de 86400, et en prenant 365.25 j. par année on obtient 5.845*10^11 ans --Ef' 7 février 2008 à 19:39 (CET)
Code
[modifier le code]Étant donné :
- que l'algorithme en français est compréhensible par tous (au moins par tous ceux qui connaissent au moins un langage) ;
- qu'il est utile pour expliquer la solution, mais l'exécuter n'a pas vraiment d'intérêt (si ce n'est pour reprogrammer le jeu) ;
- qu'aucune des implémentation n'apporte quelque chose de particulier par rapport à l'algorithme ;
j'ai supprimé toutes les versions sauf la description de l'algorithme en français. Orlodrim [discuter] 15 octobre 2010 à 18:41 (CEST)
- Bravo Anne Bauval (d) 15 octobre 2010 à 21:39 (CEST)
- Itou. Theon (d) 16 octobre 2010 à 14:16 (CEST)
Existe t-il un programme capable de trouver comment trouver la solution à la tour de Hanoi
[modifier le code]Bonjour, je crois bien qu'un tel programme n'existe pas.
Je parle d'un programme qui à partir du texte formalisé du problème de la tour de Hanoi trouve un moyen pour trouver tous les cas de la tour de Hanoi, et non un programme qui a partir d'une position de la tour de Hanoi trouve la solution.
Si un tel programme n'existe pas, il serait intéressant de rajouter ce fait dans cet article.--Nicobzz (discuter) 4 novembre 2015 à 12:29 (CET)
- Qu'appelez-vous « un moyen pour trouver tout les cas de la tour de Hanoi »? Et plus particulièrement qu'« un cas de la tour de Hanoï » --Pierre de Lyon (discuter) 4 novembre 2015 à 14:09 (CET)
- J'ai peut être pas été bien clair, je vais essayer de l'être plus:
- L’algorithme donné dans l'article dans le chapitre Solution récursive, permet, quand on lui donne les argument (n, D, A, I) (cf le chapitre en question de l'article) de trouver la séquence qui permet de mettre tout les disques à droite.
- Ce qui me semble n'existe pas comme algorithme, c'est quand on donne les arguments décrivant le problème de manière générale (c'est une séquence de mouvement où les disques doivent être déplacé de gauche à droite, mais on ne peut pas mettre un disque plus grand au dessus d'un disque plus petit , ainsi que toutes les autres règles décrivant le problème de la tour de Hanoi), cet algorithme trouverait à la fois la solution pour un cas particulier (par exemple il y'a trois disques à déplacer) et trouverait un moyen ( ou bien meme un algorithme, ce qui est un peu la même chose) pour trouver la solution quand il y'a 'n' disques à déplacer.
- Ainsi si un tel algorithme existait il permettrait de résoudre d'autres problèmes (mais je crois que ça n'existe pas ou que ça n'est pas performant).--Nicobzz (discuter) 4 novembre 2015 à 19:00 (CET)
- Si j'ai bien compris, tu cherches un algorithme qui recevrait en entrée une liste de règles de déplacements d'un certain jeu, et qui, en sortie, fournirait un algorithme qui décrirait comment résoudre ce jeu ? Si c'est bien cette question que tu poses, effectivement, il n'y a pas d'algorithme de résolution général. En effet, les règles de déplacement pourraient être celles d'une machine de Turing, le jeu consistant à savoir si cette machine finit par s'arrêter, et on sait que ce problème est indécidable. Cependant, cette formulation générale me paraît bien éloignée de l'objet de l'article pour y figurer.Theon (discuter) 5 novembre 2015 à 09:39 (CET)
- En revanche, si les règles se rapprochent plus de celle des tours de Hanoï, on est dans le cas de la programmation par contraintes et un tel algorithme existe. Les travaux récents sur le problème SAT permettent d'envisager une solution efficace. En gros on devrait pouvoir programmer le problème en PROLOG. --Pierre de Lyon (discuter) 5 novembre 2015 à 09:56 (CET)
- Si j'ai bien compris, tu cherches un algorithme qui recevrait en entrée une liste de règles de déplacements d'un certain jeu, et qui, en sortie, fournirait un algorithme qui décrirait comment résoudre ce jeu ? Si c'est bien cette question que tu poses, effectivement, il n'y a pas d'algorithme de résolution général. En effet, les règles de déplacement pourraient être celles d'une machine de Turing, le jeu consistant à savoir si cette machine finit par s'arrêter, et on sait que ce problème est indécidable. Cependant, cette formulation générale me paraît bien éloignée de l'objet de l'article pour y figurer.Theon (discuter) 5 novembre 2015 à 09:39 (CET)
- oui c'était bien la question que je me posais, merci pour vos réponses , je ne savais pas que les travaux récents sur le problème sat permettais d envisager une solution efficace.Je passes une partie de mon temps libre a essayer de créer un logiciel permettant de trouver ce genre de solutions même si il ne pourra pas trouver les solutions a tout les problèmes. Savez vous quels approches sont utilisé pour résoudre de tels problème formalisé dans le problème de satisfiabilité? Merci bien, bonne journée
- Je crois qu'une bonne source est Satisfiability modulo theories: introduction and applications par Leonardo De Moura et Nikolaj Bjørner. --Pierre de Lyon (discuter) 5 novembre 2015 à 14:19 (CET) P.S. Ahah on prêche le faux pour savoir le vrai !
- On peut ajouter Boolean Satisfiability: From Theoretical Hardness to Practical Success par Sharad Malik, Lintao Zhang. --Pierre de Lyon (discuter) 5 novembre 2015 à 14:39 (CET)
- Je crois qu'une bonne source est Satisfiability modulo theories: introduction and applications par Leonardo De Moura et Nikolaj Bjørner. --Pierre de Lyon (discuter) 5 novembre 2015 à 14:19 (CET) P.S. Ahah on prêche le faux pour savoir le vrai !
- oui c'était bien la question que je me posais, merci pour vos réponses , je ne savais pas que les travaux récents sur le problème sat permettais d envisager une solution efficace.Je passes une partie de mon temps libre a essayer de créer un logiciel permettant de trouver ce genre de solutions même si il ne pourra pas trouver les solutions a tout les problèmes. Savez vous quels approches sont utilisé pour résoudre de tels problème formalisé dans le problème de satisfiabilité? Merci bien, bonne journée
Sur les tests neuro-psychologique
[modifier le code]Voir : Discussion_Projet:Neurosciences#Tours_de_Hanoi. --Roll-Morton (discuter) 21 juin 2016 à 13:57 (CEST)