算法系列——huffman编码
哈夫曼编码,旨在对信息实现一种高效的编码,这种编码中任何一个都不是其他编码的前缀码。因此,在实际接收时,一旦匹配,就可以立即解码。
具体算法过程可以参加网上的很多教程。
给出一个自己的实现,一方面加强印象,一方面练习一下。能力有限,还请同学们多多帮助。
/////////////////////////////////////////////////////////////////////////////////
///
/// 代码并没有做仔细的参数验证等异常处理,仅仅做了功能级别的实现
///
///////////////////////////////////////////////////////////////////////////////// #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编码的更多相关文章
- 【算法】Huffman编码(数据结构+算法)
1.描述 Huffman编码,将字符串利用C++编码输出该字符串的Huffman编码. Huffman树是一种特殊结构的二叉树,由Huffman树设计的二进制前缀编码,也称为Huffman编码在通信领 ...
- 【uva 10954】Add All(算法效率--Huffman编码+优先队列)
题意:有N个数,每次选2个数合并为1个数,操作的开销就是这个新的数.直到只剩下1个数,问最小总开销. 解法:合并的操作可以转化为二叉树上的操作[建模],每次选两棵根树合并成一棵新树,新树的根权值等于两 ...
- 《数据结构与算法分析:C语言描述》复习——第十章“算法设计技巧”——Huffman编码
2014.07.06 16:47 简介: 给定一段有固定符号集合S构成的文本T,集合S中总共有n种符号.如果对于每种符号,使用一种不同的由‘0’和‘1’构成的位字符串来代替,比如: ‘a’->‘ ...
- Jcompress: 一款基于huffman编码和最小堆的压缩、解压缩小程序
前言 最近基于huffman编码和最小堆排序算法实现了一个压缩.解压缩的小程序.其源代码已经上传到github上面: Jcompress下载地址 .在本人的github上面有一个叫Utility的re ...
- [老文章搬家] 关于 Huffman 编码
按:去年接手一个项目,涉及到一个一个叫做Mxpeg的非主流视频编码格式,编解码器是厂商以源代码形式提供的,但是可能代码写的不算健壮,以至于我们tcp直连设备很正常,但是经过一个UDP数据分发服务器之后 ...
- huffman 编码
huffman压缩是一种压缩算法,其中经典的部分就是根据字符出现的频率建立huffman树,然后根据huffman树的构建结果标示每个字符.huffman编码也称为前缀编码,就是每个字符的表示形式不是 ...
- 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 ...
- DS二叉树--Huffman编码与解码
题目描述 1.问题描述 给定n个字符及其对应的权值,构造Huffman树,并进行huffman编码和译(解)码. 构造Huffman树时,要求左子树根的权值小于.等于右子树根的权值. 进行Huffma ...
- Huffman 编码压缩算法
前两天发布那个rsync算法后,想看看数据压缩的算法,知道一个经典的压缩算法Huffman算法.相信大家应该听说过 David Huffman 和他的压缩算法—— Huffman Code,一种通过字 ...
随机推荐
- 【ios开发】Block编程
1 什么是block iOS SDK 4.0开始,Apple引入了block这一特性.字面上说,block就是一个代码块,但是它的神奇之处在于在内联(inline)执行的时候(这和C++很像)还可以传 ...
- Bootstrap相关优质项目推荐
Bootstrap 编码规范by @mdo Bootstrap 编码规范:编写灵活.稳定.高质量的 HTML 和 CSS 代码的规范. jQuery API 中文手册 根据最新的 jQuery 1.1 ...
- [转]Iphone m3u8 segmenter from ffmpeg for video streaming
源地址:http://lukasz.cepowski.com/devlog/30,iphone-m3u8-segmenter-from-ffmpeg-for-video-streaming Recen ...
- IOS7学习之路八(iOS 禁止屏幕旋转的方法)
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation { retu ...
- 老鸟都应该注意的git 提交规范
不知道大家有没有看过自己项目的git 提交信息-----我看过好多次 ,不忍直视 然后提醒一起的小伙伴 :大家规范点 信息要详细, 过段时间再看下 ,还是一样. 相信很多猿都有这样的感受,对于垃圾的 ...
- iOS 应用测试最佳实践
IOS改变了移动游戏,毫无疑问.它为“移动时代”铺平了道路,通过简单的用户体验提供惊人的功能.然而涉及到测试与监控,使用iPhone/iPad移动应用程序是除了简单之外的任何事情. 随着IOS应用市场 ...
- 数模学习笔记(五)——BP神经网络
1.BP神经网络是一种前馈型网络(各神经元接受前一层的输入,并输出给下一层,没有反馈),分为input层,hide层,output层 2.BP神经网络的步骤: 1)创建一个神经网络:newff a.训 ...
- jquery.range.js左右滑动选取数值插件,动态改变进度。
作为一个初级前端工作人员,我最近在做一个关于直播的项目,其中一个功能要求是设置延迟时间, 所以就用到了jquery.range.js这个插件.插件中设置$(".single-slider&q ...
- [每日一题] OCP1z0-047 :2013-07-19 Rules of Precedence――括号的使用
这道题目的意思是你的公司决定给所有呆到5年或5年以上的所有员工每个月加50美元,然后算出总的年薪.每个月薪水:salary,每个月加到:salary+50,总的年薪: (salary+50)*12. ...
- hdu3415 Max Sum of Max-K-sub-sequence
Max Sum of Max-K-sub-sequence Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64 ...