91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python數據結構堆的示例分析

發布時間:2021-05-28 09:53:09 來源:億速云 閱讀:151 作者:小新 欄目:編程語言

小編給大家分享一下python數據結構堆的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

1、說明

堆是用數據結構來實現的一種算法:樹,數組均可。堆本身是一棵完全二叉樹。

2、特點

最大堆:所有父節點的值大于子節點的值

最小堆:所有父節點的值小于子節點的值

3、實例

class Heap(object):
    def __init__(self, list=[]):
        self.root = None
        self.list = list
        self.tree = None
        self.len = len(list)
 
    # 建堆
    def bulid_heap(self):
        if self.list != []:
            final_parent_node = int((self.len - 1) / 2)
            while final_parent_node >= 0:
                self.heapfy(final_parent_node, self.len)
                final_parent_node -= 1
 
    # 對當前節點以及向下所有子節點的一次最大節點交換
    def heapfy(self, node, len):
        node_left = 2 * node + 1
        node_right = 2 * node + 2
        max = node
        if node_left < len and self.list[node_left] > self.list[max]:
            max = node_left
        if node_right < len and self.list[node_right] > self.list[max]:
            max = node_right
        if max != node:
            self.swap(max, node)
            self.heapfy(max, len)
 
    # 交換元素方法
    def swap(self, i, j):
        self.list[j], self.list[i] = self.list[i], self.list[j]
 
    # 堆排序
    def heap_sort(self):
        len = self.len - 1
        while len >= 0:
            self.swap(0, len)
            self.heapfy(0, len)
            len -= 1
 
 
if __name__ == "__main__":
    list = [5, 7, 3, 1, 10, 0]
    heap = Heap(list)
    print("初始列表:{}".format(heap.list))
    heap.bulid_heap()
    print("堆化:{}".format(heap.list))
    heap.heap_sort()
    print("排序:{}".format(heap.list))

看完了這篇文章,相信你對“python數據結構堆的示例分析”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

望都县| 安乡县| 赤壁市| 昭平县| 娄底市| 瑞丽市| 桃江县| 商南县| 普定县| 伊川县| 牡丹江市| 县级市| 佳木斯市| 民县| 墨竹工卡县| 铁岭县| 鄯善县| 夏邑县| 杂多县| 大安市| 莲花县| 思南县| 长阳| 大余县| 福泉市| 汨罗市| 隆回县| 沂水县| 偏关县| 津南区| 彭阳县| 凤冈县| 鹿邑县| 岳西县| 阜平县| 怀集县| 武强县| 阜康市| 瑞安市| 白玉县| 邮箱|