【自考】數據結構第四章判定樹和哈夫曼樹,期末不掛科指南,第8篇

来源:https://www.cnblogs.com/happymeng/archive/2020/01/09/shujujiegou_8.html
-Advertisement-
Play Games

判定樹和哈夫曼樹 分類與判定樹 這個小節有個比較重要的概念,就是 記住即可 哈夫曼樹與哈夫曼演算法 首先瞭解一下什麼是哈夫曼樹 給定一組值p~1~,...p~k~,如何構造一棵有k個葉子且分別以這些值為權的判定樹,使得其平均比較次數最小。滿足上述條件的判定樹稱為哈夫曼樹。 哈夫曼率先給出了一個求哈夫曼 ...


判定樹和哈夫曼樹

分類與判定樹

這個小節有個比較重要的概念,就是用於描述分類過程的二叉樹稱為判定樹 記住即可

哈夫曼樹與哈夫曼演算法

首先瞭解一下什麼是哈夫曼樹

給定一組值p~1~,...p~k~,如何構造一棵有k個葉子且分別以這些值為權的判定樹,使得其平均比較次數最小。滿足上述條件的判定樹稱為哈夫曼樹。
哈夫曼率先給出了一個求哈夫曼樹的簡單而有效的方法,稱為哈夫曼演算法。

非形式的描述如下

  1. 給定的值{p~1~,p~2~,...,p~k~}構造森林{T~1~,T~2~,T~k~},其中每個T~i~為一棵只有根結點且其權為p~i~的二叉樹。
  2. 從F中選取根結點的權最小的兩棵二叉樹T~i~和T~j~,構造一棵分別以T~i~和T~j~為左、右子樹的新的二叉樹T~h~,置T~h~根結點的權為T~i~,T~j~根結點的權值之和。
  3. 從F中刪去T~i~和T~j~,並將T~h~加入F,若F中仍多於一棵二叉樹,則返回第二步,直到F中只含有一棵二叉樹為止,這棵樹就是哈夫曼樹。

參照案例

重點來了,看真題,請記住==哈夫曼樹不唯一、時刻考慮權值最小==

真題參考

動態展示這道題目的解答方法,已經去掉了結點之間的連線

哈夫曼編碼

哈夫曼編碼比較簡單,就是將某棵二叉樹中每個結點的左分支標誌“0”,右分支標誌“1”,這樣,從根到每個葉結點形成“0”/“1”序列,將該序列作為葉結點對應字元的編碼,由此得到的二進位編碼稱為哈夫曼編碼。

請讀題

設某通訊系統中一個待傳輸的文本有6個不同字元,它們的出現頻率分別是0.5,0.8,1.4,2.2,2.3,2.8,試設計哈夫曼編碼

教材中給出了樹和哈夫曼編碼,直接看一下即可

出現頻率為0.5的字元編碼為1000
出現頻率為0.8的字元編碼為1001
出現頻率為1.4的字元編碼為101
出現頻率為2.2的字元編碼為00
出現頻率為2.3的字元編碼為01
出現頻率為2.8的字元編碼為11

小結

樹形結構的應用非常廣泛,判定樹和哈夫曼樹可分別用於求解分類問題和有效分類問題以及哈夫曼編碼,哈夫曼編碼演算法的關鍵點是:每次合併具有最小權值和次小權值的兩個根結點,直到只剩下一個根結點為止。
對哈夫曼樹的每個結點的左分支和右分支分別置“0”或“1”,就可得到哈夫曼編碼。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天碰到個負載高引起的問題但是查看zabbix監控並沒有報警,檢查後發現監控取值與實際伺服器內負載不一致。 解決方法 修改zabbix模板Template OS Linux找到 Processor load (1 min average per core)修改key把 system.cpu.load ...
  • 一.介紹安裝 公司由於linux雲伺服器還沒批下來,暫時先在windows伺服器上測試。Windows版nginx使用本地Win32 API(而非Cygwin模擬層)。當前僅使用select()和poll()(1.15.9)連接處理方法(事件驅動模型),因此不應期望高性能和可伸縮性(在linux上支 ...
  • 參考穀粒學院的linux視頻教程:http://www.gulixueyuan.com/course/300/task/7091/show ...
  • CPU主要功能:處理指令、執行操作、要求進行動作、控制時間、處理數據。 結合資料庫實例CPU占用高,可能的原因是資料庫在執行大量的操作(全表查詢、大量排序等)。 由於公司沒有DBA,遇到資料庫問題只能自己排查。 一、是否存在死鎖 查詢死鎖以及解鎖的語句參考下方: 查看死鎖ID 查看死鎖ID SELE ...
  • 摘要: 下文講述在sqlserver資料庫中,將日期數據轉換為指定格式的方法分享,如下所示; 實驗環境:sqlserver 2008 R2 實現思路: 實現方法1: 使用year函數和month函數獲取相應的數值,然後採用字元串拼接的方法輸出相應的數據 實現方法2: CONVERT(varchar( ...
  • 概要 本文主要講述在 mongodb 中,怎麼更新嵌套數組的值。 使用$更新數組 測試 for (let i = 0; i < 3; i++) { let data = { name1_1: 'test' + i, arr_1: [{ a: i, b: 2 }, { a: i + 1, b: 2 } ...
  • 昨天工作的時候寫了圖片的排序介面,讓後臺自定義圖片的位置. 話不多說先上修改圖片序號的實現原理: 將5號移到2號, 此時區間 [ 2,5 ) 內的排序號都要加1. 將2號移到5號, 此時區間 ( 2,5 ] 內的排序號都要減1. 新增圖片序號的實現原理: 新增圖片序號為3,那麼區間 [ 3,∞ ) ...
  • 1 . 使用資料庫中,可能出現死鎖, 導致程式 無法正常使用. Create procedure [dbo].[sp_who_lock] ( @bKillPID Bit=0 -- 0: 查詢 1: 結束掉相對應的死鎖ID (可能導致數據異常)) as begin declare @spid int ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...