資料結構 (二叉樹 哈夫曼編碼)

2021-10-04 12:37:44 字數 1494 閱讀 4481

實現哈夫曼樹的建立演算法,並按哈夫曼樹實現哈夫曼編碼演算法。

#include

#include

#include

#include

#define maxvalue 10000

#define maxleaf 30

// 葉子結點數

#define maxnode maxleaf*2-1

//樹中結點總數

using namespace std;

typedef

struct

hnode, huffmantree[maxnode]

;typedef

struct codenode

codenode;

typedef codenode hfcode[maxleaf]

;void

createht

(huffmantree ht,

int w,

int n)

// w傳遞n個權值

//賦權值

for(i =

0; i < n; i++

) ht[i]

.weight = w[i]

;for

(i =

0; i < n-

1; i++

)else

if(ht[j]

.weight < m2&&ht[j]

.parent ==0)

}//將找出的兩顆子樹合併為一顆子樹

ht[x1]

.parent = n + i; ht[x2]

.parent = n + i;

ht[n + i]

.weight = ht[x1]

.weight + ht[x2]

.weight;

ht[n + i]

.lchild = x1;

ht[n + i]

.rchild = x2;}}

void

outputtree

(huffmantree ht,

int n)

cout << endl;

}void

createhfcode

(huffmantree ht, hfcode &hc,

int n)

//從葉子到根,逆向搜尋

strcpy

(hc[i]

.code,

&code[start]);

// 將工作區中的編碼複製到編碼表中}}

void

outputcode

(hfcode hc,

int n)

cout << endl;

}void

main()

測試:

資料結構 哈夫曼二叉樹

今天我們來實現乙個哈夫曼二叉樹又稱最優二叉樹 哈夫曼樹是帶權路徑長度最短的樹,權值較大的結點離根較近。實現原理其實很簡單對於某一些場景來說,某乙個區間段情況出現的機率是大很多的,比如成績處於中游水平的人肯定是佔大多數的,因此我們在取得這些資料時,如果按等概率去讀取會影響程式效率 所以我們可以利用哈夫...

資料結構 哈夫曼樹 哈夫曼編碼

哈夫曼樹又稱最優樹 二叉樹 是一類帶權路徑最短的樹。構造這種樹的演算法最早是由哈夫曼 huffman 1952年提出,這種樹在資訊檢索中很有用。結點之間的路徑長度 從乙個結點到另乙個結點之間的分支數目。樹的路徑長度 從樹的根到樹中每乙個結點的路徑長度之和。結點的帶權路徑長度 從該結點到樹根之間的路徑...

哈夫曼編碼 哈夫曼樹 (資料結構)

哈夫曼編碼,又稱霍夫曼編碼,是一種編碼方式,哈夫曼編碼是可變字長編碼 vlc 的一種。huffman於1952年提出一種編碼方法,該方法完全依據字元出現概率來構造異字頭的平均長度最短的碼字,有時稱之為最佳編碼,一般就叫做huffman編碼 有時也稱為霍夫曼編碼 include include inc...