Algorithmique et programmation
Travaux dirigés, 14 et 15 novembre 2002
Louis Granboulan
1 Tri Shell
-
Rappels sur le tri par insertion directe
Soit un tableau contenant n valeurs distinctes.
Le tri par insertion directe consiste à insérer un par un les
éléments de la liste dans la fin du tableau, contenant les éléments déjà triés.
-
Pour une permutation s, on appelle inversion
un couple i<j tel que s(i)>s(j).
Évaluer le nombre moyen d'inversions d'une permutation
de n éléments.
- Étudier la complexité de l'algorithme en nombre de
comparaisons et d'affectations.
- Réfléchir aux différentes façons d'améliorer cet
algorithme
- Tri Shell
L'idée est d'essayer de gagner sur le nombre d'affectations en insérant
dans des sous-listes (et donc en faisant faire de plus grands déplacements).
L'algorithme consiste en un tri par insertion dans des sous-listes
contenant de plus en plus d'éléments, de telle sorte que les éléments
soient de plus en plus proches de leur position finale (D. Shell, 1959).
On dit qu'un tableau est h-trié si les h sous-tableaux
regroupant les éléments d'indice différant d'un multiple de h
sont triés.
C'est-à-dire que les suites (xi, xi+h, xi+2h, ...)
pour i = 1, ..., h sont triées.
Pour le tri Shell,
on choisit une suite entière décroissante ht, ht-1, ... , h1
avec h1 = 1. On commence par ht-trier le tableau,
puis on continuer avec ht-1, etc.
Le hs-tri se fait par exemple par insertion directe,
pour chaque sous-tableau.
-
Prouver la correction de cet algorithme de tri.
- Prouver que le h-tri d'un ensemble k-trié donne un ensemble
k-trié. En déduire que le cas hs = 2s-1 n'est pas optimal.
- Évaluer le nombre moyen d'inversions d'une permutation 2-triée.
-
Calculer le nombre de permutations 2-triées.
- Montrer que la somme des nombres d'inversions des permutations
2-triées de n éléments (avec k=ë n/2û) est
An = åi=0..k, j=0..k |i-j|(i+j j)
(n-i-j-1 k-j).
- Prouver A2k+1=2A2k. On peut montrer que
A2k=k4k-1.
En déduire la complexité de l'algorithme dans le cas où on fait
un 2-tri suivi d'un 1-tri.
- Regarder le cas où on fait un h-tri suivi d'un 1-tri.
- Regarder le cas où hs = 2s-1.
Knuth, The Art of Computer Programming, vol. 3 :
Sorting and Searching, pp. 87--92.
2 Fractions égyptiennes
On appelle fraction égyptienne l'inverse
d'un nombre entier.
-
Trouvez plusieurs algorithmes différents pour décomposer un rationnel
positif en une somme de fractions égyptiennes distinctes.
- Réfléchir au nombre minimum de termes pour représenter
un rationnel et à la minimisation du plus grand dénominateur
d'une représentation.
http://www.ics.uci.edu/~eppstein/numth/egypt/
.
This document was translated from LATEX by
HEVEA.