Top Qs
Chronologie
Chat
Contexte

Diviser pour régner (informatique)

algorithme De Wikipédia, l'encyclopédie libre

Remove ads

En informatique, diviser pour régner (du latin « Divide ut imperes », divide and conquer en anglais) est une technique algorithmique consistant à :

  1. Diviser : découper un problème initial en sous-problèmes ;
  2. Régner : résoudre les sous-problèmes (récursivement ou directement s'ils sont assez petits) ;
  3. Combiner : calculer une solution au problème initial à partir des solutions des sous-problèmes.
Thumb
Trois étapes (diviser, régner, combiner) illustrées avec l'algorithme du tri fusion

Cette technique fournit des algorithmes efficaces pour de nombreux problèmes, comme la recherche d'un élément dans un tableau trié (recherche dichotomique), le tri (tri fusion, tri rapide), la multiplication de grands nombres (algorithme de Karatsuba) ou la transformation de Fourier discrète (transformation de Fourier rapide).

Remove ads

Exemples

Résumé
Contexte

Exemples détaillés

La table suivante donne des exemples d'algorithmes en donnant les trois étapes (diviser, régner, combiner).

Davantage d’informations Régner, Combiner ...

On peut utiliser un algorithme diviser pour régner pour effectuer la rotation d'une image d'un quart de tour.

Il s'agit d'un exemple pédagogique, enseigné par exemple en France en cours d'informatique au lycée[1]. Il est cependant, dans ce cas, inefficace en pratique. En effet, chaque pixel de l'image est déplacé autant de fois qu'il y a d'étapes Diviser alors qu'il serait possible avec d'autres algorithmes de placer directement chaque pixel à sa destination.

L'image à faire pivoter est partagée en quatre carreaux (diviser) et on déplace chaque carreau d'un quart de tour sans le faire tourner sur lui-même (régner) avant de réassembler les carreaux entre eux (combiner).

On s'arrête lorsque les carreaux ont une taille de un pixel.

Autres exemples

Voici d'autres exemples d'algorithmes diviser pour régner :

Remove ads

Histoire

Résumé
Contexte

La recherche dichotomique est formalisée dans un article de John Mauchly en 1946.

Cependant, l'idée d'utiliser une liste triée pour faciliter la recherche remonte à Babylone en -220[2].

L'algorithme d'Euclide pour calculer le plus grand commun diviseur de deux nombres peut être vu comme un algorithme diviser pour régner (les deux nombres diminuent et on se ramène à un problème plus petit).

Gauss décrit la transformée de Fourier rapide en 1805 [3] sans en faire l'analyse de complexité. La transformée de Fourier rapide est redécouverte un siècle plus tard.

John von Neumann invente le tri fusion en 1945[4]. L'algorithme de Karatsuba est inventé par Anatolii A. Karatsuba en 1960[5] : il multiplie deux nombres de n chiffres en opérations (voir notations de Landau). Cet algorithme contredit la conjecture d’Andreï Kolmogorov de 1956 qui stipule que opérations sont nécessaires. Knuth donne une méthode utilisée par les services postaux : les lettres sont triées et séparés en fonction des zones géographiques, puis en sous-zones géographies, etc.[2]

Ce tri est le tri radix, décrit pour les machines IBM à cartes (Trieur de cartes IBM (en)) dès 1929[2].

Remove ads

Intérêts

Résumé
Contexte

Complexité

La faible complexité des algorithmes diviser pour régner est l'un de leurs principaux intérêts[N 1].

Il existe plusieurs théorèmes facilitant le calcul des complexités des algorithmes de type diviser pour régner. Le principal théorème est le Master theorem. Pour des cas plus complexes on peut citer le théorème d'Akra-Bazzi.

La table suivante compare la complexité d'un algorithme naïf et de l'algorithme diviser pour régner pour quelques problèmes (voir Notations de Landau) :

Davantage d’informations ...

Parallélisme

Les algorithmes diviser pour régner sont souvent adaptés pour être exécutés sur des machines avec plusieurs processeurs.

Circuits

Il existe des circuits pour des entrées de taille fixées pour la transformation de Fourier rapide.

Il existe également des réseaux de tris pour le tri fusion, appelé le tri bitonique.

Limites

Récursivité

Les algorithmes diviser pour régner se prêtent naturellement à une écriture récursive. Mais parfois, l'exécution d'algorithmes récursifs peut conduire à un dépassement de pile. On préfère donc parfois un algorithme itératif.

Sous-problèmes redondants

Lorsque l'on applique « diviser pour régner », il n'y a pas de redondance : chaque sous-problème n’est résolu qu'une seule fois lors des appels récursifs. Par contre, lorsque les sous-problèmes sont redondants, l'algorithme récursif obtenu à partir de « diviser pour régner » peut avoir une mauvaise complexité. Prenons l'exemple du calcul du nème terme de la suite de Fibonacci. L'algorithme suivant est en temps exponentiel en n :

 fonction fibonacci(n)
     si(n = 0 ou n = 1)
         renvoyer 1
     sinon
         renvoyer fibonacci(n-1) + fibonacci(n-2)

Pour pallier cette limite, on peut mémoriser les valeurs déjà calculées afin d'éviter de résoudre les sous-problèmes déjà rencontrés. Il s'agit de la mémoïsation (aussi utilisée en programmation dynamique).

Remove ads

Notes et références

Voir aussi

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads