Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentes Révision précédente Prochaine révision | Révision précédente Prochaine révision Les deux révisions suivantes | ||
les_programmes_a_connaitre:algorithmique_premiere:tri_selection [2022/03/25 11:54] cl |
les_programmes_a_connaitre:algorithmique_premiere:tri_selection [2022/12/29 16:51] mm |
||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
- | ====== Algorithme de tri par sélection: | + | #Tri par selection |
- | ---- | + | |
- | + | ||
- | + | ||
- | Cet algorithme permet le tri d'un tableau d' | + | |
- | + | ||
- | **Algorithme: | + | |
- | {{: | + | |
- | <code python> | + | |
- | # -*- coding: utf-8 -*- | + | |
- | """ | + | |
- | Fiche de Révision - Trie par sélection | + | |
- | """ | + | |
- | + | ||
- | # Intialisation de Variable | + | |
- | tab = [98, 22, 15, 32, 2, 74, 63, 70] | + | |
- | # Fin Initialisation de Variable | + | |
- | + | ||
- | # Fonction | + | |
- | """ | + | |
- | Entrée : tab : tableau/ | + | |
- | Sortie : tab : tableau/ | + | |
- | Objectif : Trié le tableau tab, avec la méthode par sélection | + | |
- | """ | + | |
- | + | ||
- | def tri_selection(tab): | + | |
- | + | ||
- | for i in range(len(tab)): | + | |
- | + | ||
- | min = i # Intialisation de Variable | + | |
- | + | ||
- | for j in range(i+1, len(tab)): # Pour balayer tout le tableau | + | |
- | if tab[min] > tab[j]: # Si on trouve un nombre plus petit | + | |
- | min = j # Décalage | + | |
- | + | ||
- | k = tab[i] # Décalage | + | |
- | | + | |
- | | + | |
- | + | ||
- | | + | |
- | + | ||
- | + | ||
- | + | ||
- | #Fin Fonction | + | |
- | + | ||
- | # Programme Principal | + | |
- | print(tab) # Intialisation | + | |
- | print(tri_selection(tab)) # Lancement de Variable | + | |
- | </ | + | |
- | {{ : | + | |
- | La méthode par __sélection__ divise tout d’abord le tableau ( liste ) en deux : une partie triée et une autre non triée, pour délimiter cela il y a des bornes ( représenter par des variable, souvent appelés “ debut” et “fin” ). Contrairement à celle par insertion cette méthode __cherche le plus petit élément du tableau__ ( de la partie non trié ) puis cette élément __échange sa place avec celui qui est à la première place du tableau non trié__ et après ce décalage __il fera partie de la partie trié.__ | + |