哈夫曼编码,旨在对信息实现一种高效的编码,这种编码中任何一个都不是其他编码的前缀码。因此,在实际接收时,一旦匹配,就可以立即解码。

具体算法过程可以参加网上的很多教程。

给出一个自己的实现,一方面加强印象,一方面练习一下。能力有限,还请同学们多多帮助。

 /////////////////////////////////////////////////////////////////////////////////
///
/// 代码并没有做仔细的参数验证等异常处理,仅仅做了功能级别的实现
///
///////////////////////////////////////////////////////////////////////////////// #define __debug
using System;
using System.Collections.Generic;
using System.Linq; namespace Algo
{
public class ChainedNode
{
public string symbol;
public double probab;
public ChainedNode parent;
public string flag;
public bool isLeave;
} public class Huffman
{
private List<ChainedNode> nodelist; public Huffman(Dictionary<string, double> dic)
{
nodelist = new List<ChainedNode>();
foreach (var item in dic)
{
ChainedNode node = new ChainedNode();
node.probab = item.Value;
node.symbol = item.Key;
node.isLeave = true;
nodelist.Add(node);
}
} public List<ChainedNode> BuildHuffman()
{
List<ChainedNode> res = new List<ChainedNode>(); while (nodelist.Count > )
{
nodelist = (from t in nodelist orderby t.probab ascending select t).ToList(); ChainedNode first = nodelist[];
first.flag = "";
nodelist.RemoveAt();
ChainedNode second = nodelist[];
second.flag = "";
nodelist.RemoveAt(); ChainedNode c = new ChainedNode();
c.probab = first.probab + second.probab;
c.symbol = first.symbol + second.symbol; first.parent = c;
second.parent = c; nodelist.Add(c);
if (first.isLeave)
{
res.Add(first);
}
if (second.isLeave)
{
res.Add(second);
}
}
return res;
} public void GenerateCode(List<ChainedNode> head)
{
for (int i = ; i < head.Count; i++)
{
ChainedNode cn = head[i];
string symbol = cn.symbol;
string build = string.Empty;
double prop = cn.probab;
while (cn.parent != null)
{
build = cn.flag + build;
cn = cn.parent;
}
cn = head[i];
cn.flag = build;
#if __debug
Console.WriteLine("{0}:{1}:{2}.", cn.symbol, cn.probab, cn.flag);
#endif
}
}
} class Program
{
static void Main(string[] args)
{
Dictionary<string, double> dic = new Dictionary<string, double>();
dic.Add("u1", 0.1);
dic.Add("u2", 0.2);
dic.Add("u3", 0.4);
dic.Add("u4", 0.2);
dic.Add("u5", 0.1); Huffman hc = new Huffman(dic);
var list = hc.BuildHuffman();
hc.GenerateCode(list); Console.ReadLine();
}
}
}

运行结果如下图

算法系列——huffman编码的更多相关文章

  1. 【算法】Huffman编码(数据结构+算法)

    1.描述 Huffman编码,将字符串利用C++编码输出该字符串的Huffman编码. Huffman树是一种特殊结构的二叉树,由Huffman树设计的二进制前缀编码,也称为Huffman编码在通信领 ...

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

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

  3. 《数据结构与算法分析:C语言描述》复习——第十章“算法设计技巧”——Huffman编码

    2014.07.06 16:47 简介: 给定一段有固定符号集合S构成的文本T,集合S中总共有n种符号.如果对于每种符号,使用一种不同的由‘0’和‘1’构成的位字符串来代替,比如: ‘a’->‘ ...

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

    前言 最近基于huffman编码和最小堆排序算法实现了一个压缩.解压缩的小程序.其源代码已经上传到github上面: Jcompress下载地址 .在本人的github上面有一个叫Utility的re ...

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

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

  6. huffman 编码

    huffman压缩是一种压缩算法,其中经典的部分就是根据字符出现的频率建立huffman树,然后根据huffman树的构建结果标示每个字符.huffman编码也称为前缀编码,就是每个字符的表示形式不是 ...

  7. Atitit s2018.6 s6 doc list on com pc.docx Atitit s2018.6 s6 doc list on com pc.docx  Aitit algo fix 算法系列补充.docx Atiitt 兼容性提示的艺术 attilax总结.docx Atitit 应用程序容器化总结 v2 s66.docx Atitit file cms api

    Atitit s2018.6 s6  doc list on com pc.docx Atitit s2018.6 s6  doc list on com pc.docx  Aitit algo fi ...

  8. DS二叉树--Huffman编码与解码

    题目描述 1.问题描述 给定n个字符及其对应的权值,构造Huffman树,并进行huffman编码和译(解)码. 构造Huffman树时,要求左子树根的权值小于.等于右子树根的权值. 进行Huffma ...

  9. Huffman 编码压缩算法

    前两天发布那个rsync算法后,想看看数据压缩的算法,知道一个经典的压缩算法Huffman算法.相信大家应该听说过 David Huffman 和他的压缩算法—— Huffman Code,一种通过字 ...

随机推荐

  1. 实现WebService的调用与被调用

    之前一直用WCF来开发服务,可是从未用过WebService.对WebService有种很神奇的期待,都说WebService比较简单,但是从未用过就对我来说就是一种新的知识.起始让我来说WCF与We ...

  2. Python的RotatingFileHandler的Bug

    Python的库非常强大,基本能找到我们所有需要的lib.logging模块是Python中的日志记录库,借鉴了Java中的LOG4J模块的思想,能非常方便的用于记录软件执行日志. 最近有在开发自动化 ...

  3. 7 MySQL存储过程和函数

    目录: 1. 存储过程和函数概述2. 准备工作3. 存储过程操作4. 创建带参存储过程5. 查看存储过程 1. 存储过程和函数概述 MySQL的存储过程(stored procedure)和函数(st ...

  4. Asp.net MVC集成Google Calendar API(附Demo源码)

    Asp.net MVC集成Google Calendar API(附Demo源码) Google Calendar是非常方便的日程管理应用,很多人都非常熟悉.Google的应用在国内不稳定,但是在国外 ...

  5. [原]逆向iOS SDK -- _UIImageAtPath 的实现(SDK 5.1)

    注释过的反汇编代码:http://pan.baidu.com/share/link?shareid=3491166579&uk=537224442 伪代码(不精确,仅供参考): NSStrin ...

  6. JS核心概念

    Javascript本质第一篇:核心概念   很多人在使用Javascript之前都至少使用过C++.C#或Java,面向对象的编程思想已经根深蒂固,恰好Javascript在语法上借鉴了Java,虽 ...

  7. poj1001求幂

    这道题目是实质上就是高精度的乘法,虽然是带小数点的数多少次幂,但是开始我们需要将它变为整数进行求幂,然后再加上小数点,然后要考虑前导0,有效数位问题,做的时候要十分的小心 #include<io ...

  8. (翻译) Android ListView 性能优化指南

    本文翻译了Lucas Rocha的Performance Tips for Android’s ListView.这是一篇关于介绍如何提升ListView性能的文章,非常的优秀.使得我拜读之后,忍不住 ...

  9. BOOST中read_some和 boost::asio::error::eof(2)错误

    当socket读写完成调用回调函数时候一定要检查 是不是有EOF错误,如果有那么好了,另一方已经断开连接了别无选择,你也断开把.   for (;;) { boost::array < char ...

  10. SSD Buffer Pool Extension

    SSD Buffer Pool Extension 简介 SQL Server 2014中另一个非常好的功能是,可以将SSD虚拟成内存的一部分,来供SQL Server数据页缓冲区使用.通过使用SSD ...