資料結構實驗 基於哈夫曼樹的資料壓縮演算法

2021-08-20 12:58:37 字數 995 閱讀 5272

注:輸入為多行字串,以「0」結尾;例:abc def 0

此程式無法執行由單個字元組成的字串。

#include

#include

#include

using namespace std;

typedef struct

htnode,*huffmantree;

typedef char **huffmancode;

void select(huffmantree ht,int len,int &s1,int &s2)

map::iterator it;

it=maps.begin();

for(i=1;i<=n;++i,it++)         //輸入前n個單元中葉子結點的權值  

ht[i].weight=it->second; 

/*――――――――――初始化工作結束,下面開始建立赫夫曼樹――――――――――*/ 

for(i=n+1;i<=m;++i) 

//for

}// creathuffmantree

void creathuffmancode(huffmantree ht,huffmancode &hc,int n)

//求出第i個字元的編碼      

hc[i]=new char[n-start];         // 為第i 個字元編碼分配空間

strcpy(hc[i], &cd[start]);         //將求得的編碼從臨時空間cd複製到hc的當前行中

}delete cd;                             //釋放臨時空間

}void select_yuan_su(string a1,map& maps,int &n,string &h)

}is=maps.end();

is--;

for(it=maps.begin();it!=maps.end();it++)

cout<&maps)

}

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

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

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

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

資料結構 哈夫曼樹

哈夫曼樹是二叉樹的一種。被稱為最優二叉樹。實際應用中最重要的是帶權路徑長度。樹的路徑長度 樹中每個結點的路徑長度之和。權 附加在樹節點上,表示出現的概率。樹的帶權路徑長度 所有葉子結點帶權長度之和。看例項 的結點路徑長度 從d到 a的路徑,共走了兩條邊,所以為2。樹中的葉子結點有 d,e和 f。結點...