Python sort
In questa lezione parleremo del metodo sort() di Python utile per ordinare velocemente una lista in ordine crescente o decrescente.
Realizziamo dunque alcuni esempi per capirne il funzionamento.
Ordinamento crescente/decrescente di una lista con Python sort
Prendiamo in input una lista di numeri qualsiasi ed applichiamo il metodo sort su di essa per effettuare l’ordinamento in senso crescente.
numbers = [1,7,9,3,4]
numbers.sort()
print(numbers)
Parametro reverse di Python sort
Ordiniamo adesso in ordine descrescente utilizzando il parametro opzionale reverse. Se reverse è False si ordina la lista in senso crescente, è infatti il valore di default, se invece reverse è True, si ordina la lista in senso descrescente.
Ecco in esempio:
numbers = [1,7,9,3,4]
numbers.sort(reverse=True)
print(numbers)
Parametro key di sort
Il parametro key consente di specificare un criterio di ordinamento in base ad una funzione.
Facciamo un esempio ordinando una lista in base alla lunghezza dei nomi. Definiamo una funzione che calcola la lunghezza dei nomi di un array.
Applichiamo l’ordinamento impostando la key con la funzione definita.
Ecco di seguito il semplice esempio dell’algoritmo di ordinamento Python sort():
names = ['Paul','Robert','Elena','Tom']
def len_names(array):
return len(array)
names.sort(key=len_names)
print(names)
Se volessimo ordinare in ordine inverso, basterà indicare anche il parametro reverse.
names = ['Paul','Robert','Elena','Tom']
def len_names(array):
return len(array)
names.sort(reverse = True, key=len_names)
print(names)
Esempio di ordinamento con Python sort
In questo esempio proviamo ad ordinare una lista di lettere maiuscole e minuscole.
names = ['B','a','C','s']
names.sort()
print(names)
In output avremo: [‘B’, ‘C’, ‘a’, ‘s’]
Il risultato ottenuto non è quello che ci aspettavamo! Perchè? Ovviamente perché ogni lettera dell’alfabeto corrsiponde ad un carattere della codifica ASCII e le lettere maiuscole hanno una codifica diversa rispetto alle minuscole.
Possiamo ottenere un ordinamento corretto ad esempio convertendo tutti i caratteri della lista in minuscolo.
names = ['B','a','C','s']
names_order = [name.lower() for name in names]
names_order.sort()
print(names_order)
Potremmo anche scrivere in questo modo:
names = ['B','a','C','s']
for i in range(len(names)):
names[i] = names[i].lower()
names.sort()
print(names)
Conclusione
In questa lezione abbiamo visto come ordinare velocemente una lista utilizzando Python sort, nelle prossime lezioni studieremo alcuni algoritmi di ordinamento a scopo didattico.
Some useful links
How to find the maximum of N numbers
Continua la lettura su: https://www.codingcreativo.it/python-sort/ Autore del post: Coding Creativo Fonte: https://www.codingcreativo.it