日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

哈夫曼树(Huffman Tree)的介绍、画法、哈夫曼树的可视化显示(Python代码实现)

發布時間:2025/3/15 python 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 哈夫曼树(Huffman Tree)的介绍、画法、哈夫曼树的可视化显示(Python代码实现) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

https://blog.csdn.net/hanhanwanghaha寶藏女孩 歡迎您的關注!
歡迎關注微信公眾號:寶藏女孩的成長日記
如有轉載,請注明出處(如不注明,盜者必究)

目錄

    • 一、概念
    • 二、帶權路徑長度
    • 三、樹的帶權路徑長度
    • 四、舉例
    • 五、哈夫曼樹畫法舉例舉例理解
      • 5.1步驟
      • 5.2注意
    • 六、舉例(代碼實現)
      • 6.1代碼
      • 6.2運行結果
    • 注意

一、概念

帶權路徑長度最短的二叉樹,即最優二叉樹。

二、帶權路徑長度

在一顆樹中,葉子結點帶有數值,這個數值叫做權值,

權值與葉子結點到根節點層數的乘積=帶權路徑長度

三、樹的帶權路徑長度

樹中所有葉節點的帶權路徑長度之和

四、舉例


樹的帶權路徑長度計算:3x1+5x2=13

五、哈夫曼樹畫法舉例舉例理解

5.1步驟

(1) 先準備一組數字,以5,7,5,8, 9,2, 3為例
(2) 對這一組數字進行從小到大的規則排序,排序結果為2, 3, 5 ,5, 7, 8, 9
(3) 在2, 3, 5 ,5, 7, 8, 9這些數字中,選擇兩個最小的數字2,3
(4) 用類似樹杈的“樹枝”連接兩個最小的數,在頂點處計算出這兩個數字的和,比較剩下的數字和這個和的大小,再取出兩個最小的數字進行排序。
排序結果如下:

5.2注意

1.如果兩個數的和等于是下一步兩個最小數其中一個,那么這個樹直接往上生長。如上圖的5,5,左邊的5直接向上生長。如果兩個數的和比較大,不是下一步兩個最小數其中一個,那么就并列生長,例如我們的左邊5,5的和為10,而10不等于接下來選出的兩個數字5,7,所以要另外開一棵二叉樹。

2.一個節點只能生成兩個分支。

六、舉例(代碼實現)

要求:將2, 3, 5 ,5, 7, 8, 9畫出來

6.1代碼

#coding=utf-8 import pygraphviz as pgv import cv2 import os import tkinter as tkIndex = 0# 二叉樹 class BTree:lchild = Nonerchild = Nonedata = 0index = 0def __init__(self, data, index):self.data = dataself.index = indexreturndef getchild(self, lc, rc):self.lchild = lcself.rchild = rcreturn# 用來預處理哈夫曼樹 def PreHuffTree(bt, dot):if (bt == None): returndot.add_node(bt.index, label=str(bt.data))PreHuffTree(bt.lchild, dot)PreHuffTree(bt.rchild, dot)if (bt.lchild != None):dot.add_edge(bt.index, bt.lchild.index, )if (bt.rchild != None):dot.add_edge(bt.index, bt.rchild.index)return# str轉換為int類型 def GetSomeValue(hl):global Indexht = []for x in range(len(hl)):ht.append(BTree(int(hl[x]), Index))Index += 1return ht# 對數據進行連接形成二叉樹 def TransFromHuffTree(hl):global Indexif (len(hl) == 0):print("未輸入數值")returnwhile len(hl) > 1:hl = sorted(hl, key=lambda x: x.data)hf = BTree(hl[0].data + hl[1].data, Index)Index += 1hf.getchild(hl[0], hl[1])hl.pop(0)hl.pop(0)hl.append(hf)return hl[0]if __name__ == "__main__":HuffTreelist = []root = tk.Tk()values = ""HuffTreelist = []tk.Label(root, text='請輸入一系列數值,以空格間隔 :').grid(row=0, column=0) # 對Label內容進行 表格式 布局v1 = tk.StringVar()e1 = tk.Entry(root, textvariable=v1)e1.grid(row=0, column=1, padx=10, pady=5)def GetValue():global values, HuffTreelist, v1values = v1.get()values = values.split()for x in range(len(values)):if not values[x].isnumeric():v1.set("輸入錯誤:包含非數字字符")breakreturntk.Button(root, text='確認', width=10, command=GetValue).grid(row=1, column=0, sticky=tk.W, padx=10, pady=5)tk.Button(root, text='退出', width=10, command=root.quit).grid(row=1, column=1, sticky=tk.E, padx=10, pady=5)tk.mainloop()root.destroy()HuffTreelist = GetSomeValue(values)HuffTree = TransFromHuffTree(HuffTreelist)dot = pgv.AGraph(directed=False, strict=True)PreHuffTree(HuffTree, dot)dot.layout('dot')dot.draw('d:/b.png')pic = cv2.imread('d:/b.png')cv2.imshow("hufftree", pic)cv2.waitKey(0)os.remove('d:/b.png')

代碼參考:https://blog.csdn.net/qq_41654225/article/details/101302587
運行結果:

注意
要以空格分隔,否則

注意
只能輸入數字,否則

正確輸入2 3 5 5 7 8 9 ,點擊確認,再點擊退出

6.2運行結果

注意

如果pycharm沒有進行管理員運行,會出現以下報錯:

Traceback (most recent call last):File "F:/自動化測試工具/Pycharm的項目/model/teacher.py", line 107, in <module>dot.draw('d:/b.png')File "F:\Python\lib\site-packages\pygraphviz\agraph.py", line 1518, in drawfh = self._get_fh(path, 'w+b')File "F:\Python\lib\site-packages\pygraphviz\agraph.py", line 1547, in _get_fhfh = open(path, mode=mode) PermissionError: [Errno 13] Permission denied: 'd:/b.png'

希望對大家有幫助!

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的哈夫曼树(Huffman Tree)的介绍、画法、哈夫曼树的可视化显示(Python代码实现)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲视频在线播放 | 丝袜美腿亚洲一区二区图片 | 五月天综合在线 | 邪恶久久 | 欧美成人自拍视频 | av中文字幕av | 超碰五月天 | 在线免费观看黄色小视频 | 青娱乐国产| 久久91精品国产91久久小草 | 三级中文字幕在线 | 色老头在线视频 | 久久精品亚洲精品 | 色姑娘av | 免费在线视频一区二区 | 免费激情网| 欧美成人高潮一二区在线看 | 亚洲最大在线视频 | 桃色成人 | 午夜免费福利在线 | 精品一区二区人妻 | 天天色小说 | 刘亦菲毛片一区二区三区 | 日韩视频一二三 | 国产精品国产三级国产aⅴ下载 | 欧美一区二区三区免费观看 | 免费观看成人 | 欧美图片一区 | 我要爱爱网 | 成人午夜视频一区二区播放 | 91久色蝌蚪| 久久精品久久精品 | 国产精品日韩精品欧美精品 | 精品国产18久久久久久二百 | 日韩在线免费看 | 国产天堂久久 | 成 年 人 黄 色 大 片大 全 | 欧美最猛性xxxxx(亚洲精品) | 精品一区二区三区中文字幕 | а√天堂8资源中文在线 | 国产传媒国产传媒 | 69xx视频在线观看 | 偷拍综合网| 午夜少妇av | 三级国产在线观看 | 欧美一级二级视频 | av香蕉| 曰本无码人妻丰满熟妇啪啪 | 91成人免费在线观看 | 亚洲乱子伦 | 97se亚洲综合 | 最新地址在线观看 | 亚洲精品久久久久国产 | 大肉大捧一进一出好爽动态图 | 亚洲网站在线免费观看 | 欧美视频一级 | 一本到高清 | 久久久久久久 | 亚洲黄色免费 | 嫩草www| 亚洲AV乱码国产精品观看麻豆 | 天堂av中文在线观看 | 久久亚洲国产 | 尤物网址在线观看 | 午夜精品福利一区二区蜜股av | 97干视频 | 国产丰满麻豆 | 欧美丝袜一区二区三区 | 亚洲精品视频久久久 | 黄色一级视屏 | 欧美高清视频一区 | 国产xx在线观看 | 欧美毛片基地 | 美女人人操| 伊人网狼人 | 91久久精品国产91久久 | 看毛片网站 | 日本精品人妻无码免费大全 | 日韩欧美一区二区三区视频 | 福利久久久 | 逼逼av网站 | 日韩三级在线观看 | 麻豆网站在线播放 | 俄罗斯精品一区二区三区 | 久久一区二区三区四区 | 国产三级大片 | 99re这里只有精品在线 | 日韩精品国产AV | 国产精品久久久久久网站 | 毛片视频网站在线观看 | 黄在线免费 | 国产精品视频合集 | 国产福利久久久 | 精品国产乱码一区二 | 91福利小视频 | 亚洲精品久久久久久久久久 | 日本真人做爰免费视频120秒 | 在线成人小视频 | 久久亚洲精品国产 |