最小堆应用---用最小堆实现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!” 首先统计它们的出现次数,得到下面这张表: 然后根据出现的频率依次排序,放在一...
  • wxg694175346
  • wxg694175346
  • 2012年12月16日 13:01
  • 4908

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

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

【数据结构】最小堆实现哈夫曼树构造与解码

#include #include #include #include using namespace std; #define MAX 100 struct Node{ int weight...
  • u012336567
  • u012336567
  • 2015年09月08日 11:34
  • 1809

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

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

堆树(最大堆、最小堆)详解

一、堆树的定义 堆树的定义如下: (1)堆树是一颗完全二叉树; (2)堆树中某个节点的值总是不大于或不小于其孩子节点的值; (3)堆树中每个节点的子树都是堆树。 当父节点的键值总是大于或等于任何一个...
  • guoweimelon
  • guoweimelon
  • 2016年03月16日 13:30
  • 3898

利用最小堆实现哈夫曼树

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

05-树9 Huffman Codes(30 point(s)) 最小堆、哈夫曼树、dfs

05-树9 Huffman Codes(30 point(s)) In 1953, David A. Huffman published his paper "A Method for the ...
  • rzdyzx
  • rzdyzx
  • 2017年11月16日 13:31
  • 71

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

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

利用最小堆编程实现给定权值集合下构造相应霍夫曼树的算法

  • 2016年12月18日 13:20
  • 38KB
  • 下载

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

最近基于huffman编码和最小堆排序算法实现了一个压缩、解压缩的小程序Jcompress...
  • junhuster
  • junhuster
  • 2017年01月15日 12:17
  • 562
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:最小堆应用---用最小堆实现huffman树
举报原因:
原因补充:

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