Perles de Dijkstra

Perles de Dijkstra

Les Perles de Dijkstra sont un problème de backtracking en programmation énoncé par Edsger Dijkstra dans les Communications de l'ACM au début des années 1970.

L'intérêt du problème vient du fait qu'il est difficile de le programmer sans instruction GO TO[1], mais que si on le programme avec une telle instruction, on a de fortes chances aussi de se tromper, et de rendre le programme très dur à corriger.

Il a donné lieu aussi à des développements mathématiques simples.

Sommaire

Le problème

Soit un fil sur lequel on désire enfiler des perles de trois couleurs. Dijkstra propose bleu, blanc et rouge, couleurs du drapeau néerlandais, mais on peut dans une formulation plus neutre les nommer 0, 1 et 2.

Une seule contrainte existe : il ne doit pas y avoir sur le fil deux séquences adjacentes identiques.

Questions :

  • Combien de perles peut-on ainsi enfiler ?
  • Écrire l'algorithme qui réalise la plus longue séquence possible, ou le cas échéant celui qui pourra continuer indéfiniment.

L'analyse

Plausibilité

Elle commence tout d'abord avec un peu de réflexion préalable : chaque choix de perle est un choix parmi trois. Le degré de liberté dans la construction est de l'ordre de 3N. La contrainte, elle, semble diminuer plutôt en N3/2, ce qui conduit à se dire que passé un certain cap, on a assez de marge de manœuvre pour continuer indéfiniment. Mais impression n'est pas démonstration.

Familiarisation simple

Elle contient ensuite avec un peu de simulation à la main :

  • 0 est correct
  • 00 serait incorrect
  • 01 est correct
  • 010 est correct
  • 0100 et 0101 seraient incorrects
  • 0102 est correct
  • ...
  • 0102010 est correct

Nous avons ensuite un souci pour placer une perle supplémentaire :

  • 01020100 ne convient pas (répétition du 0)
  • 01020101 ne convient pas (répétition du 01)
  • 01020102 ne convient pas davantage (répétition du 0102)

Est-ce la chaîne la plus longue cherchée ? Non. Nous pouvons toujours remettre en cause un de nos choix (arbitraires) antérieurs pour voir si cela ne débloque pas la situation. Et de fait :

0102012 débloque les choses et permet de continuer. Cette procédure se nomme le backtracking.

Il n'y a plus qu'à programmer.

Programmation

Mais attention aux programmeurs négligents : si leur programme ne prévoit pas qu'il puisse y avoir de nombreux backtrackings successifs depuis la même position, ils sont partis pour rencontrer de sérieux ennuis. Ennuis qui deviennent vite inextricables si de surcroît ils ont fait usage de l'instruction GO TO, qui interdit toute prédiction facile sur les invariants valides en chaque point du programme.

Méthode mathématique

On peut construire une telle chaîne arbitrairement longue. Soit \ f le morphisme (vérifiant \ f(ab)=f(a)f(b) ) sur l'alphabet \ \{0,1\}, défini par \ f(0)=01 et \ f(1)=10. Notons \ u_n=f^n(0). On a alors: \ u_1=01; \ u_2=0110; \ u_3=01101001; \ u_4=0110100110010110; \ u_5=01101001100101101001011001101001. Ainsi l'on définit le mot de Thue et Morse, en prenant la limite de cette suite (car chaque élément de la suite est préfixe des autres). Ce mot possède plusieurs particularités mais ici celle qui nous intéresse est la suivante: on peut prouver que le mot ne comporte pas de facteur 000 ou 111. Ceci permet de décomposer le mot en produit de facteurs de la forme \ 0.1^*. Si l'on remplace ensuite chacun de ces facteurs par le nombre de 1 qu'il contient (toujours inférieur a 2), on obtient le mot \ v=210201210120210201202.....

On peut montrer que ce mot est un mot sans facteur carré.

Références

  1. L'instruction go to était une survivance venue du langage assembleur et permettant un branchement inconditionnel dans un programme; elle est peu à peu tombée en désuétude avec l'apparition des structures plus modernes permises par la programmation structurée, puis la programmation objet

Voir aussi


Wikimedia Foundation. 2010.

Contenu soumis à la licence CC-BY-SA. Source : Article Perles de Dijkstra de Wikipédia en français (auteurs)

Игры ⚽ Нужно решить контрольную?

Regardez d'autres dictionnaires:

  • Perles de dijkstra — Les Perles de Dijkstra sont un problème de backtracking en programmation énoncé par Edsger Dijkstra dans les Communications de l ACM au début des années 1970. L intérêt du problème vient du fait qu il est difficile de le programmer sans… …   Wikipédia en Français

  • Dijkstra — Edsger Dijkstra Edsger Dijkstra Edsger Wybe Dijkstra (prononciation: [ˈɛtsxər ˈwibə ˈdɛɪkstra][1]), né à Rotterdam le 11 mai 1930, et mort à Nuenen le 6  …   Wikipédia en Français

  • Edgser Wybe Dijkstra — Edsger Dijkstra Edsger Dijkstra Edsger Wybe Dijkstra (prononciation: [ˈɛtsxər ˈwibə ˈdɛɪkstra][1]), né à Rotterdam le 11 mai 1930, et mort à Nuenen le 6  …   Wikipédia en Français

  • Edsger Dijkstra — Edsger Wybe Dijkstra (prononciation: [ˈɛtsxər ˈwibə ˈdɛɪkstra][1]), né à Rotterdam le 11 mai 1930 et mort à Nuenen le 6 août 2002 …   Wikipédia en Français

  • Edsger Wybe Dijkstra — Edsger Dijkstra Edsger Dijkstra Edsger Wybe Dijkstra (prononciation: [ˈɛtsxər ˈwibə ˈdɛɪkstra][1]), né à Rotterdam le 11 mai 1930, et mort à Nuenen le 6  …   Wikipédia en Français

  • Edsger Dijsktra — Edsger Dijkstra Edsger Dijkstra Edsger Wybe Dijkstra (prononciation: [ˈɛtsxər ˈwibə ˈdɛɪkstra][1]), né à Rotterdam le 11 mai 1930, et mort à Nuenen le 6  …   Wikipédia en Français

  • Backtracking — Retour sur trace Le retour sur trace, appelé aussi backtracking en anglais, consiste à revenir légèrement en arrière sur des décisions prises afin de sortir d un blocage. La méthode des essais et erreurs constitue un exemple simple de… …   Wikipédia en Français

  • Mot Sans Facteur Carré — En combinatoire, un mot sans facteur carré est un mot qui ne contient pas la même séquence deux fois consécutivement. Pour tout alphabet d au moins trois lettres, il y a une infinité de mots sans facteur carré. Exemples Sur l alphabet {a, b}, l… …   Wikipédia en Français

  • Mot sans facteur carre — Mot sans facteur carré En combinatoire, un mot sans facteur carré est un mot qui ne contient pas la même séquence deux fois consécutivement. Pour tout alphabet d au moins trois lettres, il y a une infinité de mots sans facteur carré. Exemples Sur …   Wikipédia en Français

  • Mot sans facteur carré — En combinatoire, un mot sans facteur carré est un mot qui ne contient pas la même séquence deux fois consécutivement. Pour tout alphabet d au moins trois lettres, il y a une infinité de mots sans facteur carré. Exemples Sur l alphabet {a, b}, l… …   Wikipédia en Français

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”