Sortimine

Sortimine ehk elementide järjestamine mingi kindla reegli alusel. Pythonis on vajalik sortimisfunktsioon olemas. Lihtsal juhul saab seda kasutada järgmiselt:

list_of_numbers = [5, 2, 3, 1, 4]
another_list = sorted(list_of_numbers)
print(list_of_numbers)
print(another_list)

Annab tulemuseks:

[5, 2, 3, 1, 4]
[1, 2, 3, 4, 5]

sorted funktsioon tagastab uue järjendi, milleks on sisse antud järjendi sorditud variant. Algne (sisend) järjend ei muutu.

Teine võimalus on kasutada järjendi meetodit sort:

list_of_numbers = [5, 2, 3, 1, 4]
another_list = list_of_numbers.sort()
print(list_of_numbers)
print(another_list)

Väljund:

[1, 2, 3, 4, 5]
None

Nagu näha, list_of_numbers (algne järjend) on muutunud (on sorditud). sort meetod ise tagastab None, seepärast on see ka another_list sisu.

Tagurpidi sortimine

Eelnevalt sorditi arvud kasvavalt (eespool oli väiksem, tagapool suurem). Selleks, et tulemus saada teistpidi (eespool suurem, tagapool väiksem), saab kasutada parameetrit reverse.

list_of_numbers = [5, 2, 3, 1, 4]
print(sorted(list_of_numbers, reverse=True))

Tulemus:

[5, 4, 3, 2, 1]

Analoogselt:

list_of_numbers = [5, 2, 3, 1, 4]
list_of_numbers.sort(reverse=True)
print(list_of_numbers)
[5, 4, 3, 2, 1]

key funktsioon

Eelmiste näidete korral koosnes järjend arvudest ja nende sortimisel kasutatakse elementide väärtusi. Ehk siis 1 on eespool kui 2 jne.

Sortimine lühidalt toimub nii, et võetakse kaks elementi järjendist, võrreldakse neid ning vastavalt tulemusele tõstetakse väiksem ettepoole, suurem tahapoole.

Igakord ei piisa sellest, et võrrelda väärtusi otse. Sortimisel on võimalik kaasa anda funktsioon, mida rakendatakse elementidele enne nende võrdlemist. Ehk siis enne kahe elemendi võrdlemist (näiteks sõned “aa”, “b”, mis muidu võrdlemisel “aa” < “b”) rakendatakse funktsiooni ja võrreldakse selle tulemusi (näiteks len(“aa”) > len(“b”)). Etteantud funktsioon peab olema selline, mis võtab sisse ühe elemendi ja tagastab väärtuse. Kasutada võib nimeliselt olemasolevat funktsioon, aga võib kasutada ka lambda-funktsiooni.

names = ["ago", "mati", "reinuvader", "kasparr", "guido"]
print(sorted(names, key=lambda x: x.count('a') + x.count('r')))

Tulemus:

['guido', 'ago', 'mati', 'reinuvader', 'kasparr']

See (absurdne) näide teeb nii, et sordib sõnad selle järgi, palju neis esineb ‘a’ ja ‘r’ tähti. Eespool on sõnad, kus neid esineb vähem.

Lisaks võib kaasa anda ka reverse=True.

Olemasoleva funktsiooni kasutamine

key parameetrina võib kaasa anda ka eelnevalt defineeritud funktsiooni. Näiteks:

def second_letter(word):
    return word[1]  # here we should check that the string is long enough

names = ["aye", "xai", "mxo"]
print(sorted(names, key=second_letter))

Pange tähele, et kaasa antakse funktsiooni nimi ilma sulgudeta. Funktsioonile antakse argumendina kaasa element, funktsioon peab tagastama väärtuse, mida võrdlema hakatakse (antud näite puhul võetakse etteantud sõnest teine sümbol).

Miinimum ja maksimum

Pythonis saab kasutada funktsioone min ja max. Need leiavad vastavalt minimaalse ja maksimaalse elemendi. Kasutamine käib sarnaselt sorted funktsioonile. Esimene argument on järjend, millest hakatakse minimaalset või maksimaalset väärtust leidma. Lisaks võib kaasa anda key funktsiooni, mida kasutatakse elementide võrdlemiseks. Funktsioon tagastab ühe elemendi - vastavalt siis kas minimaalse või maksimaaalse.

print(min(names, key=lambda x: x[::-1]))

min ja max on kasutatavad ka ilma järjendita - sellisel juhul tuleb anda kaasa mitu argumenti ning nende hulgast leitakse vastav ekstreemum.

print(min("b", "a", "c"))   # -> a