电文的编码和译码(哈夫曼树的应用)

本文介绍了使用C语言实现哈夫曼树,通过链式存储结构构建二叉树,实现电文编码和译码。实验包括建立哈夫曼树、编码和译码的过程。在编码时,从叶节点通过双亲节点找到哈夫曼编码,译码时通过循环接收二进制代码并根据哈夫曼树进行解析。
摘要由CSDN通过智能技术生成


一、        实验环境

 

学宝虚拟机,VC6.0

二、        实验目的

 

从键盘接收一串电文字符,输出对应的哈夫曼编码,同时能翻译哈夫曼编码生成的代码串,输出对应的电文字符。

三、        实验内容

1.用C语言实现二叉树的链式(二叉链表)存储结构;

2.实现二叉树的基本操作的有关算法(二叉树的建立、各种遍历等);

3.定义二叉树的静态链表结构,并利用这种结构存储哈夫曼树,利用哈夫曼树解决编码及译码的实际应用问题。

 

四、        数据结构与算法思想描述

(1)建立哈夫曼树:

若已知n个字符的出现概率的“权值”,构造出具有2n-1个结点的哈夫曼树(采用静态链表存储结构),

(2)编码:

  从哈夫曼树的叶节点出发,通过双亲找到h[f],通过h[f]的左孩子和右孩子来判断该叶子是左分支还是右分支。如果是右边,则为‘1’。反之为‘0’。放入数组cd[start]里,重复上述过程,直至找到树根。倒序输出数组的编码值。

(3)译码:

步骤1:设计一循环结构接收用户输入的二进制代码存入ch[1..m],每循环一次接收一个“0”或“1”,同时记录代码的长度;最后将长度存入m中;设k指针的初值=1;

步骤2:将f指针指向根节点。利用指针k扫描到二进制代码ch[]的第k位,若当前第k位二进制数ch[k] =“0”则f往其左孩子移

  • 15
    点赞
  • 103
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值