Today: Saturday 12 June 2021 , 11:41 pm


advertisment
search


Problème du drapeau hollandais

Dernière mise à jour 1 Jour , 4 heure 23 Vues

Advertisement
In this page talks about ( Problème du drapeau hollandais ) It was sent to us on 11/06/2021 and was presented on 11/06/2021 and the last update on this page on 11/06/2021

Votre commentaire


Entrez le code
 
Le problème du drapeau hollandais est un problème de programmation, présenté par Edsger DijkstraDans le livre : , le chapitre 14 (pages 111-116) a pour titre : « The Problem of the Dutch national flag »., qui consiste à réorganiser une collection d'éléments identifiés par leur couleur, sachant que seules trois couleurs sont présentes (par exemple, rouge, blanc, bleu, dans le cas du drapeau des Pays-Bas).
Étant donné un nombre quelconque des balles rouges, blanches et bleues alignées dans n'importe quel ordre, le problème est à les réarranger dans le bon ordre: les bleues d'abord, puis les blanches, puis les rouges.
Au départ les balles sont disposées dans un ordre quelconque. À la fin, toutes les balles de la même couleur doivent être rangées ensemble et l'ordre entre les couleurs doit être respecté, ainsi que l'ordre que les balles de même couleur avaient les unes par rapport aux autres dans l'agencement initial : on trouve par exemple d'abord tous les objets bleus, puis tous les objets blancs et enfin tous les objets rouges et si une balle rouge apparaissait avant une autre balle rouge, elle doit apparaître dans cet ordre dans l'agencement final (on appelle un tel algorithme de tri un algorithme stable). L'espace mémoire auxiliaire doit aussi être optimisé.
La solution est à la base d'algorithmes de tris, en particulier de variantes de quicksort qui doivent être stables. Autrement dit on cherche à définir un algorithme qui regroupe des items en trois catégories, ceux qui sont plus petits, ceux qui sont plus grands, et ceux qui sont égaux à un élément spécifique sans trop bouleverser l'ordre initialCe cas apparaît en particulier dans les chaînes de caractères triées avec la version de Quicksort à plusieurs clefs. Voir : .

Description

L'algorithme proposé par Edsger Dijkstra est un algorithme qui montre que l'on peut ordonner une collection de n objets en un nombre linéaire de tests de couleurs, alors que les algorithmes de tri sans information sur les clés des objets font un nombre de comparaisons entre clés en ordre de grandeur plus grand (en moyenne et au pire de l'ordre de n\log n) .

Le cas d'un tableau

Ce problème peut être vu comme le fait d'ordonner les éléments d'un tableau.
Supposons que tous les éléments du tableau puissent être classés en trois catégories (petit, moyen et grand).
Par exemple, si tous les éléments entre 0 et 1, les petits sont ceux entre 0 et 0,1 (non compris), les moyens entre 0,1 (compris) et 0,3 (non compris) et les grand ceux entre 0,3 (compris) et 1. Le problème est alors de mettre tous les petits éléments au début du tableau, puis les moyens, puis les grands éléments à la fin du tableau.
Un algorithme possible est de faire grandir l'ensemble des grands éléments depuis la fin, celui des petits depuis le milieu, et de garder les éléments moyens juste au-dessus des petits. L'algorithme garde en mémoire trois indices, le début du groupe des grands, la fin du groupe des petits et la fin du groupe des moyens. Les éléments à trier sont entre le groupe moyen et le grand groupe. À chaque étape l'algorithme regarde l'élément juste après les éléments moyens classés. Si cet élément est grand, il est échangé avec l'élément avant l'élément le plus grand classé et son indice est décrémenté, s'il est petit il est échangé avec le plus petit élément moyen et son indice ainsi que l'indice de fin des moyens est incrémenté, sinon l'élément n'est pas bougé et seul l'indice de fin des éléments moyens est incrémenté. La complexité de cet algorithme est \Theta(n) déplacements et comparaisons .
=== Algorithme général ===
On considère n éléments rangés dans un tableau T1..n (n≥1). Chaque élément a une clé qui ne peut prendre que l’une des trois valeurs : blanc, bleu ou rouge. On souhaite trier le tableau de sorte qu’on ait à gauche tous les éléments bleus (s’il y en a), puis au milieu tous les éléments blancs (s’il y en a), et à droite tous les éléments rouges (s’il y en a).

Principe

Le principe est le suivant. On part des deux extrémités, comme dans la procédure partition du tri rapide. On s’intéresse à la case courante du tableau T, dont on teste la couleur, et selon le résultat on procède à des échanges, de sorte qu'on ait à chaque étape à gauche une zone de bleus, puis une zone de blancs, puis une zone inconnue et enfin, à droite une zone de rouges.
On va utiliser une variable b (blue), indice de la première case après la zone bleue connue; une variable w (white), indice de la première case après la zone blanche connue et une variable r (red), indice de la première case avant la zone rouge connue. L'algorithme élémentaire consiste à réduire la zone inconnue comprise entre les bornes w et r par test de la couleur de la case w.
Tableau à une étape donnée :
{ class="wikitable"
-
bleu bleu blanc blanc blanc blanc inconnue inconnue inconnue inconnue rouge rouge
-
1 2 3 4 5 6 7 8 9 10 11 12
b = 3 ; w = 7 ; r = 10.

Pseudocode


Enum couleur {bleu, blanc, rouge
Lexique : b, w, r : entier ; T : tab1..n de couleur
Début
b ← 1; w ← 1 ; r ← n
tant que w ≤ r faire
si Tw = blanc alors w ← w+1
sinon si Tw = bleu alors
{échanger Tb et Tw ;
b ← b+1 ; w ← w+1
sinon // Tw = rouge
{échanger Tw avec Tr ;
r ← r-1
fintantque ;
Fin

Complexité

La complexité au mieux est de n tests de couleur et 0 échange (cas par exemple où tous les éléments sont de couleur bleue) et au pire de 2n tests de couleur et n échanges (par exemple, cas où tous les éléments sont de couleur rouge).
Dans le cas où l'on considère que toutes les couleurs sont également possibles en chaque case du tableau, on peut montrer que le nombre moyen de tests est de (5/3)n et que le nombre moyen d'échanges est de (2/3)n .

Voir aussi

  • Liens externes

  • Une explication interactive de l'exécution de cet algorithme, pour ranger deux ou trois couleurs.
  • Références


    D
     
    commentaires

    Il n'y a pas encore de commentaires




    vu pour la dernière fois
    Most vists