CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

Trier une liste Python

vg72
vg72
Niveau 9
18 janvier 2015 à 18:16:39

Bonjour,
Sauriez vous comment faire un programme qui trie une liste fournie dans l'ordre croissant mais SANS utiliser la méthode .sort()
SVP
Merci

Dark_Chouhartem
Dark_Chouhartem
Niveau 11
18 janvier 2015 à 18:30:26
from random import randrange

def is_sorted(l):
    if len(l) == 0:
        return True
    dl = [ l[i+1] - l[i] for i in range(len(l)-1) ]
    for e in dl:
        if e < 0 :
            return False
    return True

def shuffle(l):
    for i in range(len(l) - 1, 0, -1):
        j = randrange(i + 1)
        l[i],l[j] = l[j],l[i]
    return l

def sort(l):
    while is_sorted(l) == False:
        l = shuffle(l)
    return l

Est un code admissible :oui: :

>>> sort([5,8,9,1,2])
[1, 2, 5, 8, 9]

Mais est-ce optimal :question:

Lagrangien
Lagrangien
Niveau 8
21 janvier 2015 à 13:37:52

Salut,

voilà le code le plus simple auquel je puisse penser sans utiliser la méthode sort().
Ca utilise la fonction min(), mais bon min() est elle-même une fonction extrêmement simple à coder.


def tri(L):
    M = []
    while L:
        m = min(L)
        L.remove(m)
        M.append(m)
    return M

#### Exemple d'utilisation
import random

L = [random.random() for i in range(10)]
print(L)
M = tri(list(L)) #list(L) car on veut faire le tri sur une copie de L
print(M)


Sous forums
  • Aide à l'achat Mac
  • Internet
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Steam Deck
  • Hardware
La vidéo du moment