溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python在自定義類上使用堆排序的示例

發(fā)布時(shí)間:2021-04-27 15:16:52 來源:億速云 閱讀:152 作者:小新 欄目:編程語言

小編給大家分享一下python在自定義類上使用堆排序的示例,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

Python主要用來做什么

Python主要應(yīng)用于:1、Web開發(fā);2、數(shù)據(jù)科學(xué)研究;3、網(wǎng)絡(luò)爬蟲;4、嵌入式應(yīng)用開發(fā);5、游戲開發(fā);6、桌面應(yīng)用開發(fā)。

1、說明

我們留給自定義類的唯一解決方案是實(shí)際重寫比較運(yùn)算符。遺憾的是,這使我們局限于對(duì)每個(gè)類只能進(jìn)行一種比較。在我們的示例中,我們被局限于按年份對(duì)Movie對(duì)象進(jìn)行排序。

但是,它確實(shí)讓我們演示了在自定義類上使用堆排序。我們來定義Movie類:

2、實(shí)例

from heapq import heappop, heappush
 
class Movie:
    def __init__(self, title, year):
        self.title = title
        self.year = year
 
    def __str__(self):
        return str.format("Title: {}, Year: {}", self.title, self.year)
 
    def __lt__(self, other):
        return self.year < other.year
 
    def __gt__(self, other):
        return other.__lt__(self)
 
    def __eq__(self, other):
        return self.year == other.year
 
    def __ne__(self, other):
        return not self.__eq__(other)

看完了這篇文章,相信你對(duì)“python在自定義類上使用堆排序的示例”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI