哈夫曼树建立C语言.doc

上传人:M****1 文档编号:562847321 上传时间:2022-10-08 格式:DOC 页数:3 大小:16.51KB
返回 下载 相关 举报
哈夫曼树建立C语言.doc_第1页
第1页 / 共3页
哈夫曼树建立C语言.doc_第2页
第2页 / 共3页
哈夫曼树建立C语言.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《哈夫曼树建立C语言.doc》由会员分享,可在线阅读,更多相关《哈夫曼树建立C语言.doc(3页珍藏版)》请在金锄头文库上搜索。

1、哈夫曼树建立#define n 4#define m 2*n-1#define max 9998#include typedef struct treeint data;int lchild,rchild,prnt;hufmtree; /*建立哈夫曼树函数*/void hufm(hufmtree tm)int i,j,p1,p2;int small1,small2,f;for(i=0;im;i+) /*初始化*/ti.data=0;ti.lchild=0;ti.rchild=0;ti.prnt=0;printf(请输入N个叶子结点的值:); /*输入N个叶子结点的值*/for(i=0;in;i

2、+)scanf(%d,&f);ti.data=f;for(i=n;im;i+)p1=0;p2=0;small1=max;small2=max; /*small1,small2里存放最小和次小的结点值*/for(j=0;j=i-1;j+)if(tj.prnt=0)if(tj.datasmall1)small2=small1;small1=tj.data;p2=p1;p1=j;else if(tj.datasmall2)small2=tj.data;p2=j;tp1.prnt=i+1;tp2.prnt=i+1;ti.lchild=p1+1;ti.rchild=p2+1;ti.data=tp1.data+tp2.data;void main()int i;hufmtree tm;hufm(t);printf(输出哈夫曼数组:n); for(i=0;im;i+)printf(结点值%5d,ti.data);printf(双亲结点值%5d,ti.prnt);printf(左孩子结点值%5d,ti.lchild);printf(右孩子结点值%5dn,ti.rchild);

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号