前言
本文主要給大家了關(guān)于利用Python按學(xué)生年齡排序的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹:
問題:定義一個Class:包含姓名name、性別gender、年齡age,需要按年齡給學(xué)生排序。
輸入:包含學(xué)生對象的List。
輸出:按照年齡age進行排序好的List。
思路1:使用冒泡排序,比較相鄰的學(xué)生,如果第一個學(xué)生的age值比第二個學(xué)生的age值大,那么就整體交換這兩個元素。持續(xù)每次對越來越少的元素重復(fù)上面的步驟。一直到?jīng)]有任何一對學(xué)生需要比較。
思路2:使用Python內(nèi)建方法sorted()。
(這個問題其實是筆者面試時候手寫的一個實際問題,比較面向小白,我們可以通過這樣一個簡單的問題復(fù)習(xí)Python的一些基礎(chǔ)知識點)
1. 前期準(zhǔn)備
1.1 定義Class
class Student(object): def __init__(self, name, gender, age): self.__name = name self.__gender = gender self.__age = age # 取得age屬性 def getAge(self): return self.__age # 打印 def printStudent(self): return self.__name, self.__gender, self.__age
1.2 生成包含隨機學(xué)生對象的List
# 生成包含隨機學(xué)生對象的listdef generateStudent(num): # num為需要生成的測試對象數(shù) list = [] for i in range(num): randName = ''.join(random.sample(string.ascii_letters, 4)) randGender = random.choice(['Male', 'FeMale']) randAge = random.randint(10,30) s = Student(randName, randGender, randAge) list.append(s) return list
2. 開始排序
2.1 使用冒泡排序
思路已在開頭介紹,我們直接來看代碼:
def sortStudent(list): for i in range(len(list)): for j in range(1, len(list)-i): if list[j-1].getAge() > list[j].getAge(): list[j-1], list[j] = list[j], list[j-1] return list
2.2 使用Python內(nèi)建方法sorted
配合lambda表達(dá)式使用,非常簡潔,代碼如下:
sorted(list, key=lambda student: student.getAge()) # 將對象的age屬性作為排序的Key
我們在這里補充一下 sorted() 和 lambda表達(dá)式 的相關(guān)知識點:
2.2.1 sorted(iterable, *, key=None, reverse=False)
官方文檔
關(guān)于參數(shù)的說明:
key specifies a function of one argument that is used to extract a comparison key from each list element: key=str.lower. The default value is None (compare the elements directly).
reverse is a boolean value. If set to True, then the list elements are sorted as if each comparison were reversed.
關(guān)于穩(wěn)定性的說明:
新聞熱點
疑難解答