利用c++实现哈希慢算法

本文讲述了作者在使用C++实现哈弗曼编码时遇到的问题,主要涉及std::priority_queue容器的使用。作者首先介绍了哈弗曼树的基本概念,然后描述了在构建哈弗曼树过程中,由于std::priority_queue按权值而非对象大小比较导致的问题。通过尝试存储hNode指针以及自定义function object解决比较问题,最终成功实现了哈弗曼编码算法。
摘要由CSDN通过智能技术生成

我想每个计算机专业的学生或多或少都接触过哈夫曼编码,数据结构中的老问题了。大体就是给出一些字符,和这些字符的出现频率,让你为这些字符设计一个二进制编码,要求频率最高的字符的编码最短。解决的方法是构造一棵哈夫曼树(二叉树),其基本思路是,每次从这些字符中挑出两个频率最低的,然后构造一个新的结点,使新结点的左右孩子指针分别指向那两个节点。我想这个大家都很清楚了,我就不多说了。主要讲下这次我用C++实现时遇到的问题。首先,我定义了一个哈夫曼树结点:

class hNode
{
 public:
  friend bool operator > (hNode n1,hNode n2); //定义了大于符号,供优先队列排列使用
  hNode(string d="",int i=0,hNode* l = NULL,hNode* r =NULL):left(l),right(r),data(d),value(i){} 
  hNode* left;
  hNode* right;
  string data; //储存的字符串
  int value; //字符串出现的次数
};

bool operator >(hNode n1,hNode n2)
{
 return n1.value > n2.value;
}

仅仅只是存放数据的对象,所以只有一个构造函数,并且所有的data member都是公有的。
  这此写这个算法会遇到大麻烦,主要因为是用了std::priority_queue容器。当时考虑到在哈夫曼中要每次挑选两个频率最小(即出现次数最小,我那个hNode里的value是出现的次数),很自然的就想到了std::priority_queue容器,优先队列每次都会弹出队列中权值最高的元素,这个特性无疑是实现哈夫曼算

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值