欢迎来到天天文库
浏览记录
ID:55967650
大小:82.00 KB
页数:13页
时间:2020-06-18
《哈夫曼树实验报告材料.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、数据结构实验报告实验名称:实验三哈夫曼树学生:班级:班序号:学号:日期:程序分析:2.1存储结构:二叉树2.2程序流程:templateclassBiTree{public:BiTree();//构造函数,其前序序列由键盘输入~BiTree(void);//析构函数BiNode*Getroot();//获得指向根结点的指针protected:BiNode*root;//指向根结点的头指针};//声明类BiTree及定义结构BiNodeData:二叉树是由一个根结点和两棵互不相交的左右子树构成二叉树中的结点具有相同数据类型及层次关
2、系示意图:rootlchildparentrchild哈夫曼树类的数据域,继承节点类型为int的二叉树classHuffmanTree:publicBiTreedata:HCode*HCodeTable;//编码表inttSize;//编码表中的总字符数二叉树的节点结构templatestructBiNode//二叉树的结点结构{Tdata;//记录数据Tlchild;//左孩子Trchild;//右孩子Tparent;//双亲};示意图:TdataTlchildTrchildTparent编码表的节点结构structHCode{
3、chardata;//编码表中的字符charcode[100];//该字符对应的编码};示意图:chardatacharcode[100]待编码字符串由键盘输入,输入时用链表存储,链表节点为structNode{charcharacter;//输入的字符unsignedintcount;//该字符的权值boolused;//建立树的时候该字符是否使用过Node*next;//保存下一个节点的地址};Node*nextboolusedunsignedintcountcharcharacter示意图:2.3关键算法分析:1.初始化函数(voidHuffmanT
4、ree::Init(stringInput))算法伪代码:1.初始化链表的头结点2.获得输入字符串的第一个字符,并将其插入到链表尾部,n=1(n记录的是链表中字符的个数)3.从字符串第2个字符开始,逐个取出字符串中的字符3.1将当前取出的字符与链表中已经存在的字符逐个比较,如果当前取出的字符与链表中已经存在的某个字符相同,则链表中该字符的权值加1。3.2如果当前取出的字符与链表中已经存在的字符都不相同,则将其加入到链表尾部,同时n++4.tSize=n(tSize记录链表中字符总数,即哈夫曼树中叶子节点总数)5.创建哈夫曼树6.销毁链表源代码:voidHu
5、ffmanTree::Init(stringInput){Node*front=newNode;//初始化链表的头结点if(!front)throwexception("堆空间用尽");front->next=NULL;front->character=NULL;front->count=0;Node*pfront=front;charch=Input[0];//获得第一个字符Node*New1=newNode;if(!New1)throwexception("堆空间用尽");New1->character=ch;//将第一个字符插入链表New1->cou
6、nt=1;New1->next=pfront->next;pfront->next=New1;boolreplace=0;//判断在已经写入链表的字符中是否有与当前读出的字符相同的字符intn=1;//统计链表中字符个数for(inti=1;inext;if((int)pfront->character==(int)ch)//如果在链表中有与当前字符相同的字符,该字符权值加1{pfront->count++;replace=1;break
7、;}}while(pfront->next);if(!replace)//如果在链表中没找到与当前字符相同的字符,则将该字符作为新成员插入链表{Node*New=newNode;if(!New)throwexception("堆空间用尽");New->character=ch;New->count=1;New->next=pfront->next;pfront->next=New;n++;}pfront=front;//重置pfront和replace变量为默认值replace=0;}tSize=n;//tSize记录的是编码表中字符个数CreateHTr
8、ee(front,n);//创建哈夫曼树pfront=front;
此文档下载收益归作者所有