最小堆应用---用最小堆实现huffman树

原创 2006年05月29日 23:29:00

#include"MinHeap.h"

template<class T> class HuffmanTree;
template<class T>
class TreeNode{
 friend class HuffmanTree<T>;
 private:
  T data;
  TreeNode<T> *left,*right;
 public:
  TreeNode(T value){
   data = value;
   left = right = NULL;
  }
  TreeNode(){
   left = right = NULL;
  }
  bool operator > (const TreeNode &node){
    return data > node.data;
  }
  bool operator < (const TreeNode &node){
    return data < node.data;
  }
  bool operator == (const TreeNode &node){
    return data == node.data;
  }
     bool operator >= (const TreeNode &node){
    return data >= node.data;
  }
};

template <class T>
class HuffmanTree{
 public:
  HuffmanTree();
  HuffmanTree(T value[],int n);
 protected:
  TreeNode<T> *JoinTree(TreeNode<T> &node1,TreeNode<T> &node2);
  TreeNode<T> *root;
};

template<class T>
HuffmanTree<T>::HuffmanTree():root(NULL){
}

template<class T>
HuffmanTree<T>::HuffmanTree(T value[],int n):root(NULL){
  TreeNode<T> *nodes = new TreeNode<T>[n];
  TreeNode<T> leftNode,rightNode;
  int i = 0;
  for(i = 0; i < n; i++){
    nodes[i] = TreeNode<T>(value[i]);
  }
  MinHeap< TreeNode<T> > *m_heap = new MinHeap< TreeNode<T> >(nodes,n);
 
  for(i = 0; i < n-1; i++){
   m_heap->RemoveMin(leftNode);
   m_heap->RemoveMin(rightNode);
   root = JoinTree(leftNode,rightNode);
   m_heap->Insert(*root);
  }
}

template<class T>
TreeNode<T> *HuffmanTree<T>::JoinTree(TreeNode<T> &node1,TreeNode<T> &node2){
  TreeNode<T> *r = new TreeNode<T>;
  r->left = &node1;
  r->right = &node2;
  r->data = node1.data + node2.data;
  return r;
}

相关文章推荐

[C++]数据结构:使用最小堆创建霍夫曼编码树HuffmanTree的过程

二话不多说,首先我们先来看个霍夫曼编码树的栗子。 假设我们想要压缩的是这个字符串: “beep boop beer!” 首先统计它们的出现次数,得到下面这张表: 然后根据出现的频率依次排序,放在一...

贪心算法之最小堆实现霍夫曼编码

贪心算法之最小堆实现霍夫曼编码 实现之前需要学习的地方: 如果你不了解堆、堆的插入、堆的删除,可以先看下我前面几篇博客 http://blog.csdn.net/u011068702/artic...

利用最小堆实现哈夫曼树

  • 2015年11月17日 14:31
  • 6KB
  • 下载

二叉树应用-最小堆类模板的实现(数据结构基础 第6周)

最小堆是一种特殊的完全二叉树,优先队列往往就是用其来实现的。 这里简单实现了最小堆类模板的基本操作,并使用二叉树基础-实现堆结构(数据结构基础 第5周) 题目对其进行了测试。源码 //test....

最小堆 实现的霍夫曼编码

  • 2016年12月22日 11:17
  • 6KB
  • 下载

最小堆的实现和操作

  • 2016年12月03日 19:47
  • 5KB
  • 下载

Jcompress: 一款基于huffman编码和最小堆的压缩、解压缩小程序

最近基于huffman编码和最小堆排序算法实现了一个压缩、解压缩的小程序Jcompress...

最小堆的应用之哈弗曼树5.2

哈夫曼树又称最优二叉树,是一种带权路径长度最短的二叉树。所谓树的带权路径长度,就是树中所有的叶结点的权值乘上其到根结点的路径长度的乘积之和。哈弗曼编码是它的重要应用,哈弗曼编码是一种无前缀编码。 ...

最小堆定时器的实现以及与网络编程中的多路IO复用的应用

转载地址:http://blog.csdn.net/w616589292/article/details/45694987 在开发Linux网络程序时,通常需要维护多个定时器,如维护...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:最小堆应用---用最小堆实现huffman树
举报原因:
原因补充:

(最多只允许输入30个字)