1. 优先队列小析

     优先队列的模板: template <class T, class Container = vector<T>,class Compare = less<typename Container::value_type> > class priority_queue;

 可以看出priority_queue的模板声明带有三个参数,T为数据类型,Container为保存数据的容器,,Compare为元素比较方式,其中Container必须是用数组实现的容器,比如vector,deque,不能用list.STL里面容器默认用的是 vector. 比较方式默认用 operator< ,所以如果你把后面俩个参数 缺省的话,优先队列就是大顶堆。如果要用到小顶堆,则一般要把模板的三个参数都带进去。STL里面定义了一个仿函数 greater<Type>,对于基本类型可以用这个仿函数声明小顶堆。引用自(DanielWang_).
  在求解Huffman编码里面,我们需要用到小顶堆性质,而且元素还是指针元素.因此我们使用如下的方式定义优先队列,把模板的三个参数都带进去,并且还自定义了仿函数.

typedef struct HTNode{
char c;
unsigned int freq;
HTNode *lchild, *rchild; //构造函数
HTNode(char key='\0', unsigned int fr=, HTNode *l=NULL, HTNode *r=NULL):
c(key),freq(fr),lchild(l),rchild(r){}; }HTNode,*pNode; //重载优先队列里的比较运算符
struct cmp{
bool operator()(pNode node1, pNode node2){
return node1->freq > node2->freq;
}
}; //含有指针类型的优先队列
priority_queue<pNode, vector<pNode>, cmp> pq;

  2. 具体实现代码 


在打印Huffman 编码的时候,还用到了string的一个函数,erase,即删除某个字符.因为end()返回string的最后一个字符的下一个位置,那么就可以用如下的方法删除最后一个字符.
str.erase(str.end()-1); //删除最后一个字符
 
*************************************************************************
> File Name: Huffman_code_pg.cpp
> Author: He Xingjie
> Mail: gxmshxj@.com
> Created Time: 2014年06月06日 星期五 08时57分01秒
> Description:
************************************************************************/
#include<iostream>
#include<queue>
#include<vector>
#include<cstdio>
#include<stack> using namespace std; typedef struct HTNode{
char c;
unsigned int freq;
HTNode *lchild, *rchild; //构造函数
HTNode(char key='\0', unsigned int fr=, HTNode *l=NULL, HTNode *r=NULL):
c(key),freq(fr),lchild(l),rchild(r){}; }HTNode,*pNode; //重载优先队列里的比较运算符
struct cmp{
bool operator()(pNode node1, pNode node2){
return node1->freq > node2->freq;
}
}; //含有指针类型的优先队列
priority_queue<pNode, vector<pNode>, cmp> pq; void HuffmanCode(int n)
{
pNode l, r; //从优先队列中找出优先级最小的两个元素,合并,并
//把它加入到优先队列中
while (pq.size() > )
{
pNode z = new HTNode; l = pq.top();
pq.pop();
r = pq.top();
pq.pop(); z->lchild = l;
z->rchild = r;
z->freq = l->freq + r->freq; pq.push(z);
}
} void PrintCode(pNode t, string str)
{
//中序递归遍历HuffmanTree求解HuffmanCode
if (t == NULL)
return;
if (t->lchild)
{
str += '';
PrintCode(t->lchild, str);
} //叶子节点
if (t->lchild == NULL && t->rchild == NULL)
{
cout<<t->c<<"'s code: "<<str<<endl;
} str.erase(str.end()-); //删除最后一个字符 if (t->rchild)
{
str += '';
PrintCode(t->rchild, str);
}
} void DFS(HTNode *t)
{
HTNode *node;
stack<pNode, vector<pNode> > pstack; pstack.push(t);
node = pstack.top();
pstack.pop(); while (pstack.size() > )
{
if (node->lchild)
{
pstack.push(node->lchild);
node = node->lchild;
}
else if(node->rchild)
{
pstack.push(node->rchild);
node = node->rchild;
}
else
{
printf("%d ", node->freq);
node = pstack.top();
pstack.pop();
}
}
} int main()
{
int n, i;
FILE *fp;
char tmp;
string str; fp = fopen("in.txt", "r");
if (fp ==NULL)
{
printf("fopen error!\n");
return -;
} //输入大小
fscanf(fp, "%d", &n);
fscanf(fp, "%c", &tmp); //输入数据
for (i=; i<n; i++)
{
char c;
int freq;
pNode p = new HTNode; fscanf(fp, "%c%d", &c, &freq);
p->c = c;
p->freq = freq; fscanf(fp, "%c", &tmp); pq.push(p);
} HuffmanCode(n);
PrintCode(pq.top(), str); return ;
}

 参考:

http://www.cplusplus.com/reference/queue/priority_queue/?kw=priority_queue

http://blog.csdn.net/liuzhanchen1987/article/details/7856893

http://blog.csdn.net/daniel_ustc/article/details/17613359

优先队列求解Huffman编码 c++的更多相关文章

  1. 优先队列实现Huffman编码

    首先把所有的字符加入到优先队列,然后每次弹出两个结点,用这两个结点作为左右孩子,构造一个子树,子树的跟结点的权值为左右孩子的权值的和,然后将子树插入到优先队列,重复这个步骤,直到优先队列中只有一个结点 ...

  2. 【uva 10954】Add All(算法效率--Huffman编码+优先队列)

    题意:有N个数,每次选2个数合并为1个数,操作的开销就是这个新的数.直到只剩下1个数,问最小总开销. 解法:合并的操作可以转化为二叉树上的操作[建模],每次选两棵根树合并成一棵新树,新树的根权值等于两 ...

  3. Huffman编码

    #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <cstdio> #include <cstri ...

  4. 【数据压缩】Huffman编码

    1. 压缩编码概述 数据压缩在日常生活极为常见,平常所用到jpg.mp3均采用数据压缩(采用Huffman编码)以减少占用空间.编码\(C\)是指从字符空间\(A\)到码字表\(X\)的映射.数据压缩 ...

  5. Huffman编码(Huffman树)

    [0]README 0.1) 本文总结于 数据结构与算法分析, 源代码均为原创, 旨在 理解 "Huffman编码(Huffman树)" 的idea 并用源代码加以实现: 0.2) ...

  6. UVA 10954 Add All 全部相加 (Huffman编码)

    题意:给你n个数的集合,每次选两个删除,把它们的和放回集合,直到集合的数只剩下一个,每次操作的开销是那两个数的和,求最小开销. Huffman编码.Huffman编码对于着一颗二叉树,这里的数对应着单 ...

  7. 用优先队列构造Huffman Tree及判断是否为最优编码的应用

    前言 我们知道,要构造Huffman Tree,每次都要从堆中弹出最小的两个权重的节点,然后把这两个权重的值相加存放到新的节点中,同时让这两个节点分别成为新节点的左右儿子,再把新节点插入到堆中.假设节 ...

  8. [老文章搬家] 关于 Huffman 编码

    按:去年接手一个项目,涉及到一个一个叫做Mxpeg的非主流视频编码格式,编解码器是厂商以源代码形式提供的,但是可能代码写的不算健壮,以至于我们tcp直连设备很正常,但是经过一个UDP数据分发服务器之后 ...

  9. Huffman编码实现电文的转码与译码

    //first thing:thanks to my teacher---chenrong      Dalian Maritime university /* 构造Huffman Tree思路: ( ...

随机推荐

  1. 用代码控制UI界面

           public class MainActivity extends Activity { //当第一次创建Activity时回调该方法 @Override protected void ...

  2. 【概念笔记】JavaEE - web part1

    IT`huhui前言录 想对学习的内容进行下简易的总结方便自己回头复习. 但是还有很多地方是不完善的需要慢慢修改. 持续更新. Web 服务器 IIS 微软主推 Apache C写的 Tomcat j ...

  3. 写在Python前

    Python是用C编写的一种解释型语言,和shell一样,变量可以直接使用,而且就像C中的宏替换,但是Python同样支持进行底层的调用,可以很容易的和各种语言进行融合,俗称"胶水语言&qu ...

  4. 统计《ASP.Net特供视频教程》总长度

    忽然想统计一下我录制过的视频一共多长时间,由于视频文件很多,一共72个,挨个打开进行累加不是程序员应该想起的办法.所以就打算写一个程序来完成这件事,最核心的问题就是“获得一个视频文件的时长”. ffm ...

  5. WP8:在Unity中使用OpenXLive

    Unity 4.2正式版开始添加了对Windows 8.Windows Phone 8等其他平台的支持,而且开发者可以免费使用Unity引擎来开发游戏了.而作为Windows Phone和Window ...

  6. 用c#开发微信 (17) 微活动 3 投票活动 (文本投票)

    前面介绍了微活动<大转盘> 和 <刮刮卡>,这次介绍下微投票,微投票分二种,一种是文本投票, 一种是图片投票.   下面介绍文本投票的详细步骤: 1. 新建文本投票活动     ...

  7. starUML使用教程

    starUML使用教程 下载与安装 先从官网下载软件,这个版本是收费的,但可以先进行试用.也可以使用免费版,基本UML依然齐全,但用起来感觉没有收费版好用. 下载之后按照安装说明,一步步安装就可以了. ...

  8. 从NullObject谈C#6.0改进

    前言 本文来聊一聊我们经常会做的空值检查问题,从一个简单的空值检查Any Where,到设计模式的NullObjectPattern,再到C#6.0“可能”会提供的语法,让我们体验一次语言开发上的“持 ...

  9. C#设计模式(23)——备忘录模式(Memento Pattern)

    一.引言 在上一篇博文分享了访问者模式,访问者模式的实现是把作用于某种数据结构上的操作封装到访问者中,使得操作和数据结构隔离.而今天要介绍的备忘者模式与命令模式有点相似,不同的是,命令模式保存的是发起 ...

  10. jenkins2 pipeline介绍

    文章来自:http://www.ciandcd.com 文中的代码来自可以从github下载: https://github.com/ciandcd   什么是jenkins2的pipeline?   ...