亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++實現哈夫曼樹簡單創建與遍歷的方法

2020-01-26 15:27:02
字體:
來源:轉載
供稿:網友

本文以實例形式講述了C++實現哈夫曼樹簡單創建與遍歷的方法,比較經典的C++算法。

本例實現的功能為:給定n個帶權的節點,如何構造一棵n個帶有給定權值的葉節點的二叉樹,使其帶全路徑長度WPL最小。

據此構造出最優樹算法如下:

哈夫曼算法:

1. 將n個權值分別為w1,w2,w3,....wn-1,wn的節點按權值遞增排序,將每個權值作為一棵二叉樹。構成n棵二叉樹森林F={T1,T2,T3,T4,...Tn},其中每個二叉樹都只有一個權值,其左右字數為空

2. 在森林F中選取根節點權值最小二叉樹,作為左右字數構成一棵新的二叉樹,并使得新的二叉樹的根節點為
其左右字數權值之和,其中葉子都是最初的樹

3. 在森林F中刪除這兩棵樹,同時將新得到的二叉樹代替這兩個樹加入到森林F中,因此森林中二叉樹的個數比以前少一顆

4. 對新的森林重復2和3,知道森林中只有一棵樹位置,這棵樹就是哈夫曼樹.

#include <iostream>using namespace std;#define LEAFNUM 10        //葉子節點數,也就是權值樹#define HUFNUM 2*LEAFNUM#define MAXWEIGHT 999.9//*********存儲結構***********class HufTree;//***** Node**********class NODE{private: char Data;          //節點的數據域 double Weight;   //節點的權值域 int Lchild,Rchild,Parent;   //節點的左孩子右孩子及雙親域public: NODE()            //構造函數 { Data = '/0'; Weight = 0; Lchild = -1; Rchild = -1; Parent = -1;        //給節點的數據初始化 } int Re_L(){return Lchild;} int Re_R(){return Rchild;} char Re_Data(){return Data;} double Re_Weight(){return Weight;} friend class HufTree;     //聲明友元};//Node//********HufTree類**********class HufTree{private: int NodeNum; NODE HufArry[HUFNUM];public: HufTree(){NodeNum = 0;} void SetHuf(int,double,char);   //設置權值與數據域 void CreatHuf();          //創建哈夫曼樹 void SelectMin(int,int&,int&);   //查找哈夫曼樹種兩個權值最小的樹 void Find_Root_and_Print();       //查找樹根節點位置 void PrintHuf(int);          //遍歷哈夫曼樹};//huftree void HufTree::SetHuf(int i,double wei,char ch){ HufArry[i].Data = ch; HufArry[i].Weight = wei;}void HufTree::CreatHuf(){ cout<<"每次查詢兩個最小樹的位置:"<<endl; for(int i = LEAFNUM; i < HUFNUM - 1; i++) { int p1 = 0; int p2 = 0; SelectMin(i,p1,p2);           //找出當前樹種權值最小的兩顆樹  cout<<p1<<"   < - >    "<<p2<<endl; HufArry[p1].Parent = i;   //設置兩顆最小樹的雙親 HufArry[p2].Parent = i; HufArry[i].Lchild = p1;   //設置這棵3節點的樹的根的權值以及孩子 HufArry[i].Rchild = p2;    HufArry[i].Weight = HufArry[p1].Weight + HufArry[p2].Weight; } cout<<"************************"<<endl;}void HufTree::SelectMin(int i,int &p1,int &p2){ int least1 = MAXWEIGHT; int least2 = MAXWEIGHT; for(int j = 0; j < i; j++) { if(HufArry[j].Parent == -1) {    if(HufArry[j].Weight < least1)  {  least2 = least1;  least1 = HufArry[j].Weight;  p2 = p1;  p1 = j;  }  else  {  if(HufArry[j].Weight < least2)  {   least2 = HufArry[j].Weight;   p2 = j;  }  } } }}void HufTree::Find_Root_and_Print(){ int root; for(int i = 0; i < HUFNUM - 1; i++) { if(HufArry[i].Parent == -1) {  root = i;  break; } } PrintHuf(root);}void HufTree::PrintHuf(int position){ if(NodeNum == LEAFNUM) {  return; } else { if(HufArry[position].Data != '/0') //如果是葉子節點 {  cout<<"權值:"<<HufArry[position].Weight<<"<-> 數據:"<<HufArry[position].Data<<" 此節點為葉子"<<endl;  NodeNum = NodeNum + 1; } else {  cout<<"權值:"<<HufArry[position].Weight<<" 此節點無數據域,不是葉子"<<endl;  PrintHuf(HufArry[position].Lchild);  PrintHuf(HufArry[position].Rchild); } }   }int main(){ HufTree Tree; cout<<"請輸入"<<LEAFNUM<<"對(權值,數據):"<<endl; double wei; char ch; for(int i = 0; i < LEAFNUM; i++) { cin>>wei; cin>>ch; Tree.SetHuf(i,wei,ch); } Tree.CreatHuf();     //創建哈夫曼樹 Tree.Find_Root_and_Print();           //遍歷哈夫曼樹 return 0;}

測試結果:

1 a2 b5 c7 d4 e13 f3 g6 h11 i8 l
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
人体精品一二三区| 欧美一级成年大片在线观看| 国产精品视频999| 亚洲精品之草原avav久久| 国产精品揄拍一区二区| 91精品国产综合久久香蕉922| 韩剧1988在线观看免费完整版| 欧美精品video| 亚洲欧美国产一本综合首页| 成人中文字幕+乱码+中文字幕| 懂色av中文一区二区三区天美| 日韩精品极品视频| 欧美激情免费在线| 色综合久综合久久综合久鬼88| 久久久久亚洲精品成人网小说| 欧美自拍大量在线观看| 亚洲天堂成人在线视频| 18一19gay欧美视频网站| 久久久综合免费视频| 久久久久www| 5252色成人免费视频| 国产精品美女无圣光视频| 国产精品手机播放| 亚洲最大成人网色| 欧美丝袜美女中出在线| 日韩av免费在线看| 日本最新高清不卡中文字幕| 在线视频欧美性高潮| 成人夜晚看av| 国内精品美女av在线播放| 日韩在线观看网站| 在线国产精品播放| 亚洲在线免费观看| 国产日韩av高清| 国产亚洲精品久久久久动| 亚洲人成网站色ww在线| 中文字幕亚洲精品| 亚洲成人av在线| 亚洲精品国产综合区久久久久久久| 欧美极品少妇xxxxⅹ喷水| 亚洲欧美日韩网| 岛国av一区二区三区| 久热在线中文字幕色999舞| 国产精品高潮呻吟视频| 影音先锋欧美在线资源| 91精品国产综合久久香蕉922| 久久99久久久久久久噜噜| 国产精品亚洲一区二区三区| 久久久精品中文字幕| 欧美在线视频播放| 日韩国产欧美精品一区二区三区| 国产成+人+综合+亚洲欧洲| 国产精品福利在线观看网址| 91精品国产沙发| 国产精品永久免费视频| 欧美丰满少妇xxxx| 国产精品视频xxx| 国产精品流白浆视频| 欧美激情网站在线观看| 中文字幕在线看视频国产欧美| 国产精品久久一区主播| 日韩av在线不卡| 国产精品男女猛烈高潮激情| 精品国产精品自拍| 亚洲人成网站999久久久综合| 成人激情视频免费在线| 91av在线播放| 国产午夜精品视频| 亚洲成色777777女色窝| 日韩美女在线播放| 午夜精品久久久久久久99黑人| 在线播放亚洲激情| 久久久久久久久综合| 精品国产网站地址| 国产亚洲精品久久久久久777| 日韩欧美精品中文字幕| 午夜精品福利视频| 国产成人精品视频在线观看| 超碰97人人做人人爱少妇| 亚洲精品一区在线观看香蕉| 97视频在线观看播放| 日韩暖暖在线视频| 亚洲欧美日韩国产精品| 日韩hd视频在线观看| 国产亚洲精品一区二555| 国产精品91久久久久久| 成人福利网站在线观看11| 精品视频—区二区三区免费| 狠狠做深爱婷婷久久综合一区| 九九热这里只有在线精品视| 久久6精品影院| 国产ts人妖一区二区三区| 亚洲女同精品视频| 日韩精品在线免费观看视频| 日韩av在线免费观看一区| 国产精品成人国产乱一区| 亚洲国产精品久久精品怡红院| 日韩电影免费观看在线| 日韩乱码在线视频| 一区二区三区www| 欧美中文字幕在线| 日韩精品在线免费| 一本一本久久a久久精品牛牛影视| 国产极品精品在线观看| 中文字幕精品www乱入免费视频| 久久久影视精品| 97久久伊人激情网| 伊人伊成久久人综合网小说| 中文字幕成人精品久久不卡| 亚洲欧洲日产国码av系列天堂| 国产精品老女人精品视频| 久久综合伊人77777蜜臀| 日韩av一区在线| 精品国偷自产在线| 中文字幕av一区| 粉嫩老牛aⅴ一区二区三区| 国产精品欧美激情在线播放| 国产日产亚洲精品| 孩xxxx性bbbb欧美| 久久久久久久色| 欧美色欧美亚洲高清在线视频| 国产精品久久久久久av福利| 亚洲人成网站免费播放| 亚洲人成电影网站色xx| 视频在线观看99| 欧美高清视频一区二区| 亚洲国产精品久久91精品| 欧美激情图片区| 国产成人精品免费视频| 久久国产精品久久国产精品| 日韩一区二区在线视频| 午夜欧美大片免费观看| 国产欧美在线视频| 1769国产精品| 欧美午夜电影在线| 久久久视频精品| 亚洲石原莉奈一区二区在线观看| 亚洲国产精品久久久久秋霞蜜臀| 国产精品视频一| 国产日韩在线看| 亚洲成人久久久久| 国产精品一区二区3区| 久久久免费高清电视剧观看| 久久国产精品视频| 亚洲日本中文字幕免费在线不卡| 51视频国产精品一区二区| 欧美夫妻性生活视频| 亚洲电影免费观看高清完整版在线观看| 国产精品扒开腿做| 亚洲女人被黑人巨大进入| 国产精品一区二区三区毛片淫片| 久久国产精品偷| 国产精品久久中文| 欧美精品福利在线| 午夜精品一区二区三区在线播放| 美日韩精品免费观看视频| 九九九久久国产免费| 欧美日韩免费区域视频在线观看| 欧美与黑人午夜性猛交久久久| 国产欧美日韩视频| 日本午夜人人精品| 国产福利成人在线| 欧美精品精品精品精品免费| 日韩欧美在线一区|