Professional Documents
Culture Documents
Huffman Code
Huffman Code
Huffman Code
1. Create a leaf node for each unique character and build a min heap
of all leaf nodes (Min Heap is used as a priority queue. The value
of frequency field is used to compare two nodes in min heap.
Initially, the least frequent character is at root)
2. Extract two nodes with the minimum frequency from the min
heap.
3. Create a new internal node with frequency equal to the sum of the
two nodes frequencies. Make the first extracted node as its left
child and the other extracted node as its right child. Add this node
to the min heap.
4. Repeat steps#2 and #3 until the heap contains only one node. The
remaining node is the root node and the tree is complete.
Example
(character, Frequency) =
{(a, 5),
(b, 9),
(c, 12),
(d, 13),
(e, 16),
(f, 45)}
character code-word
f --- 0
c --- 100
d --- 101
a --- 1100
b --- 1101
e --- 111
Example
• Say we want to encode a text with the characters a,
b,…, g occurring with the following frequencies:
a b c d e f g
Frequency 37 18 29 13 30 17 6
Fixed-Length Code
a b c d e f g
Frequency 37 18 29 13 30 17 6
Fixed-length 000 001 010 011 100 101 110
code
g,6 d,13
Constructing a Huffman Code
g,6 d,13
Constructing a Huffman Code
g,6 d,13
Constructing a Huffman Code
48 e,30 35 a,37
g,6 d,13
Constructing a Huffman Code
e,30 35 a,37 48
g,6 d,13
Constructing a Huffman Code
e,30 35 a,37 48
g,6 d,13
Constructing a Huffman Code
65 a,37 48
e,30 35 19 c,29
a,37 48 65
19 c,29 e,30 35
a,37 48 65
19 c,29 e,30 35
85 65
e,30 35
a,37 48
f,17 b,18
19 c,29
g,6 d,13
Constructing a Huffman Code
65 85
e,30 35
a,37 48
g,6 d,13
Constructing a Huffman Code
150
65 85
e,30 35
a,37 48
g,6 d,13
Resulting Code
0 1
a 10
b 011
0 1 0 1
c 111
e a d 1101
0 1 0 1
e 00
f b c f 010
0 1 g 1100
g d