_bryce_ a écrit :
Bonjour
je recherche les algo de tri suivant:
- Rapide - Fusion
- Bulle
Merci d'avance PS: Une recherche m'aurai surement donné une réponse mais si quelqu'un a la gentillesse de me les faire parvenir ça serai vraiment sympa.
|
Tri à bulle
Tu balayes ton tableau. Si l'élément que tu traites n'est pas à sa place par rapport à l'élément suivant tu inverses les deux éléments.
Tu recommence le balayage complet tant que tu as eu au-moins une inversion (tu peux optimiser ce tri en mémorisant l'endroit de la première inversion et en ne recommençant le balayage qu'à partir de cet endroit lors de l'itération suivante)
Tri rapide
Tu découpes ton tableau en 2 parties à partir d'un pivot.
Tu balayes la partie de gauche à la recherche d'un élément plus grand que le pivot
Tu balayes la partie de droite à la recherche d'un élément plus petit que le pivot
Dès que t'as trouvé les deux éléments tu les intervertis.
Dès que t'as tout balayé à gauche et à droite, si la partie de gauche a plus d'un élément tu relances l'algo complet (récursivité) sur la partie de gauche. Idem pour la droite.
Tri fusion
Tu découpes ton tableau en 2 puis encore en 2 etc jusqu'à arriver à n paquets de 2 éléments.
Pour chaque paquet de deux éléments, tu tries les deux éléments l'un par rapport à l'autre.
Ensuite, tu prends les n paquets 2 à 2 et tu les fusionnes ensemble. Chaque fusion te redonne un paquet. Tu recommences alors la fusion sur les nouveaux paquets jusqu'à ce que tu n'aies plus qu'un paquet totalement trié.
Message édité par Sve@r le 27-02-2005 à 18:40:33
---------------
Vous ne pouvez pas apporter la prospérité au pauvre en la retirant au riche.