数据结构—最优二叉树及其应用

数据结构—最优二叉树及其应用

ID:22288639

大小:141.51 KB

页数:9页

时间:2018-10-28

数据结构—最优二叉树及其应用_第1页
数据结构—最优二叉树及其应用_第2页
数据结构—最优二叉树及其应用_第3页
数据结构—最优二叉树及其应用_第4页
数据结构—最优二叉树及其应用_第5页
资源描述:

《数据结构—最优二叉树及其应用》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、实验最优二叉树及其应用1.程序设计简介本实验程序用于验证最优二叉树的算法。树的存储采用带孩子的双亲顺序存储方法。2.源程序//最优二叉树#include#includeusingnamespacestd;//定义结点类型templatestructhufnode{Twei;//权值intprt;//指昀父结点的指针域(结点元素的下标)intlch;//左指针域(结点元素的下标)intrch;//右指针域(结点元素的下标)};//由于数组下标一般是非负数整数,因此4

2、以用-1作为空指针值templateclasshuffman_BT{intnn;//叶子结点的个数hufnode*p,intk,int*i,int*j);voidprt_hufm_BT();//输出最优二叉树存储空间状、};//生成最优二义树te

3、mplatevoidhuffman_BT::creat_hufm_BT(intn,Tw[J){//n是叶子结点的个数,w是叶子结点的权值数组hufnode*p;intnn=n;m=n*2-l;BT=newhufnodelch=-l;(p+k)-〉rch=,1;}for(k=0;k

4、权值(p+k)->wei=w[k];}for(k=n;kprt=k;(p+j)-〉prt=k;//合并构成新的二叉树(p+k)-〉lch=i;(p+k)->rch=j;(p+k)-〉wei=(p+i)-〉wei+(p+j)-〉wei;}}templatevoidhuffman_BT::select(hufnode*p,intk,int*i,int*j){/

5、/在前K-l个结点中选择权值最小的两个根结点i和jTw;intn=0;while(nwei;*i=n;while(nwei)prt==-1)){*i=n;w=(p+n)->wei;}n++;}n=0;while((nprt!=-l)

6、

7、(n==(*i)))n++;w=(p+n)->wei;*j=n;while(n

8、)->weiprt==-1))*j=n;w=(p+n)-〉wei;n++;}{n=(*i);*i=•*j=n;}}templatevoidhuffman_BT::prt_hufm_BT(){hufnode*p;intk;P=BT;cout«,'k,,«setw(7)«HWEr,«setw(7)«',PRTn«setw(7)«',LCH"«setw(7)«"RCH"«endl;for(k=0;k<2*nn-l;k++){cout«k«setw(

9、7)«(p+k)->wei«setw(7)«(p+k)->prt<lch«setw(7)«(p+k)->rch«endl;}}voidmain(){int*w;intop;inti;huffman_BTb;do{cout«"l-输入结点权值•’《endl;COUt«n2-生成最优二叉cout«"3-退出程序”《endl;cout«”请选择操作:[]";cout«nbbH;cin»op;switch(op){case1:c0Ut«”请输入结点的个数:intsum;cin»

10、sum;w=newintfsum];cout«"请依次输入权值:M«endl;for(i=0;i

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。