; x6 e6 {: {/ N+ Welse . F3 I9 a+ A% X1 _5 A1 \, l4 [$ e: J- k8 m9 ?, O2 o3 ?
score=’优’;0 g2 y" Q' M' b" q, O; `8 a
3 f R1 S/ @8 b1 \; ]+ Y- }, ?. ]8 n Q
此判定过程可以用图6.33(a)的判定树来表示。如果学生规模很大,该算法需反复多次执行,就应该考虑算法执行的时间问题。在实际应用中,学生的成绩呈正态分布,大部分在70~89分之间,优秀和不及格的概率较小。假设不及格、及格、中、良、优的百分比为5%、12%、40%、35%、8%,则上述算法80%以上的成绩需要进行三次或三次以上的比较才能得到结果。若以这些百分比值5,12,40,35,8为权值,使用哈夫曼算法来构造一棵判定树,则得到图6.33(b)所示的判定过程,可使多数成绩经过较少的比较即可得到结果。但由于每个判定框都有两次比较,将两次比较分开,得到如图6.33(c)所示的判定树,按此判定树构造程序,显然可以大大减少比较次数。 5 B: z6 \) H; N3 E6 a3 O3 G3 `; E ! Y! H2 B# v0 T/ a8 j& L, S$ t x x . d6 B: D4 o; y) C/ l
) E# ^1 ~; B2 U( \, p7 C1 }" j7 R , Q9 V) f& u( S9 y1 W
( I# G; x! _$ Q1 d: M$ g% D
& i8 k0 Y6 x5 T! J' g: M5 o v7 h
: q$ V' E$ ?+ @( j x<60 70≤x<80' J$ R: K3 M3 Q' O1 e! M7 k. A
( a9 a' L$ L5 P- ] Y N Y N & Y% @( C! f I
0 y6 u8 B4 T6 o6 D
不及格 x<70 中 80≤x<90 4 f [0 ^) p5 |% z ) f+ T; w0 ^2 F7 O4 G Y N Y N 8 [( Z5 r& ~4 ~6 o& y! j/ [; {& j- }7 ?7 r* K+ Q& ^
及格 x<80 良 60≤x<70% u( P4 _) N4 [. I3 z& `! i) `0 R
3 Z: M \# j) _% }$ O+ f! j
Y N Y N% j2 T/ ~6 s, h( w
3 Z6 \: O4 z. J6 d5 Y: l$ Y5 ]+ a 中 x<90 x<60 及格9 o0 W2 J4 f# N9 |7 c/ O
4 r. _5 \6 V, M
Y N Y N ) E$ U# }' |3 K# [- }7 G& Q
. Q4 l' G# Y1 K$ g
良 优 不及格 优) u j: J+ T3 |0 Z
$ p, V! z8 F. _; j% W ( y$ X* R4 G' h# Q9 |+ V$ I" O- u# H' F; W1 O9 Y' A; O
x<80 4 c, E* o+ I- v* s/ `/ \' B# O1 Y, e1 L1 l4 V' n! }
Y! D* |4 h. T* K3 C
' c2 J* ?- n/ S" n# C* Y3 O2 L x<70 x<90 3 c; A, f, v1 F( b3 l7 h& n
# J0 u; m) O* |3 l& }2 `" c7 T8 d
Y N Y N. t8 P! I& q v+ {/ L& J
$ c8 [1 r* {6 V x<60 中 良 优 7 J& F) x. g4 @ / Y0 l4 O+ v+ x+ P& v. f Y N) A% a$ z& X9 h M# H( C% `, d
* d' Z% w8 B4 c( C2 Q
不及格 及格 % @8 U4 Q; \8 T% \5 U1 [5 v$ L: s& q 1 w/ z; t$ y- B7 }/ d' {, [! O" U (c) 5 L5 J8 o: f% g( y. | 0 ^4 V+ Z, E; }* m. ^$ t9 O 图6.33 百分制转换五级制的判定过程 1 [: k K- y9 g+ a O7 O7 M) l& Z) j1 I- R- U 6 {7 R- w6 M( L1 R4 }1 ^1 V+ M; e5 ~9 H
哈夫曼树在通信、编码和数据压缩等技术领域也有着广泛的应用。下面我们介绍哈夫曼树在数据编码中的应用,即数据的最小冗余编码问题。7 [+ z- m" {) {4 K. Z
* j( A, ^6 s! }2 H8 `/ S& _) o# {) `在数据通信中,需要将传送的文字转换成二进制的字符串,用0,1码的不同排列来表示字符。例如,需传送的报文为“AFTER DATA EAR ARE ART AREA”,这里用到的字符集为“A,E,R,T,F,D”,各字母出现的次数为{8,4,5,3,1,1}。现要求为这些字母设计编码。要区别6个字母,最简单的二进制编码方式是等长编码,固定采用3位二进制,可分别用000、001、010、011、100、101对“A,E,R,T,F,D”进行编码发送,当对方接收报文时再按照三位一分进行译码。显然编码的长度取决报文中不同字符的个数。若报文中可能出现26个不同字符,则固定编码长度为5。然而,传送报文时总是希望总长度尽可能短。在实际应用中,各个字符的出现频度或使用次数是不相同的,如A、B、C的使用频率远远高于X、Y、Z,自然会想到设计编码时,让使用频率高的用短码,使用频率低的用长码,以优化整个报文编码。但这样长短不等的编码又会产生一个新问题,即如何解译成原文?除非设计时能够保证任何一个字符的编码都不是同一字符集中另一个字符的编码的前缀,符合此要求的编码称为前缀编码。* l/ q" R1 s! ~2 O' f/ \7 F
. {/ j& s9 }! h. m& d( C我们用上述各字母出现的次数{8,4,5,3,1,1}作为权构造哈夫曼树,如图6.36所示。约定左分支表示字符“0”,右分支表示字符“1”,则可以从根结点到叶子结点的路径的分支上的字符组成的字符串作为该叶子对应字符的编码。可以证明,如此得到的必为二进制前缀编码,而且是一种最优前缀编码。我们称这样的树为哈夫曼编码树,由此得到的编码称为哈夫曼编码。本例中字母A、E、R、T、F、D的哈夫曼编码分别为11、00、01、011、0100、0101。可以看出,出现次数较多的字母A、E、R,具有最短的编码,长度均为2;而出现次数最少的字母F、D,具有最长的编码,长度均为4。报文的最短传送长度为: , A" n4 C( c* |. F- E 5 `. a1 z9 D$ h/ b! \6 [6 E4 S7 w7 y: K 6) Z( B p& l- Y7 J$ ^. i. g3 u) g
; k( [0 J+ D O7 _4 w! i
L=WPL=S(wklk)=4×2+5×2+8×2+3×3+1×4+1×4=51 . ]2 B, X3 c% O9 h& V3 g' ]5 r% K* n* R* [ P
k=1 ; f. B$ C8 d% q$ q: k# T* Y* T" i: v: Z+ l; \+ B
若采用等长编码,报文的传送长度为 3 z ~. t; L" ? 7 W3 b; G2 m7 v, @; x6 FL=8×3+4×3+5×3+3×3+1×3+1×3=66 6 k+ a: t4 H! e7 [& @! p8 V2 }2 O" t5 d
显然,哈夫曼编码比等长编码所得到的报文长度要短得多。哈夫曼编码是最优前缀编码。 g& e/ S4 _# @+ v+ P " g- V! u! N6 l4 w2 D9 S B 3 K+ O3 j3 d, A3 p0 n
4 g7 a) d1 e- O$ t' j: M" n 22; B( Z: f, Y0 \8 p
1 V! }' h9 M' ? 0 10 q- D- s) S e5 ^7 i
; X' t5 i" D& l- I* w
9 13+ `9 ?% L0 `/ N5 u/ N1 ]. E' ?( f
# t1 U7 T X- j" n8 B, H 0 1 0 16 f* @' k: {: A) b! [
7 y/ I! J5 l8 `) v: v2 U w6 e
4 5 5 8 ! S! c' s6 k% r0 k* ` 9 e, g4 i; V n& l+ ~* Y1 R) V E 0 1 R A 7 F% L8 e c) f3 |* ^. s! O# m& @5 K# f5 y. P
2 3 9 @5 q& G! X) q 6 H% _9 r6 u- \( U" B' R 0 1 T9 V o* c2 H, o% k
1 \% u3 w, I- o1 Y% m% y- V 1 1 ! X9 h/ t' h$ S# c x8 \: z" C6 a6 v+ N# x F D ' H' x6 ^$ }9 D9 z8 S3 T & h0 _4 m. f( H* Q# x8 a图6. 36 哈夫曼编码树 4 l+ H8 Q' i) C2 T, z | 9 q" B' x7 x) ?! J8 p一个任意长度的编码序列可被唯一地翻译为一个字符序列(单词)。依次取出编码序列中的0或1,从哈夫曼编码树的根结点开始寻找一条路径。若为0,则沿着左分支向下走;若为1,则沿着右分支向下走。每到达一个叶子外结点时,就译出一个相应的字符,然后再回到哈夫曼树的根结点处,依次译出余下的字符,最后得到一个单词。作者: liuyaliss 时间: 2009-9-6 15:10
哈夫曼树的应用 2 Z& r5 f1 N. i哈夫曼树的应用十分广泛,在不同的应用中,对叶子结点的权和带权路径长度有不同的解释。& V$ [ _4 H- v0 Y# r, |5 @' `
0 x' G9 s3 g* Z' m& E, }: f" t
哈夫曼树的应用之一是用于优化判断过程,利用哈夫曼树得到最佳判定算法。例如,将百分制转换成五级制的算法。显然,此算法很简单,只需利用if语句描述即可。 7 j3 b& O, V) r/ L" Z7 ]) B" I# v* c1 p: i3 v+ i) m* b
if ( x<60) 5 o2 ?8 [" c7 |1 j: s+ k & x8 Q/ E8 y4 W6 | score=’不及格’; , ]# Z% X& r) e8 `8 g9 ~ L6 n; i0 w
else if ( x<70)" @1 ~/ |$ U3 v
: P! o+ O( L9 J score=’及格’;& Y, g3 S% Q# v3 w
* W$ h' e* \( D& D9 relse if ( x<80)+ ~+ k; M4 E. Z
+ W1 | N9 L8 z: k$ \ score=’中’;6 _3 Z; v: X: W& |# \, E0 J. i
% R8 R6 V2 H. l1 Selse if ( x<90)% H- ^; E/ \! u+ k4 z3 t
" H0 v6 g4 J! E+ p+ M score=’良’; ' A9 G. v( p: G0 e7 j + D! K; [7 C; ]& I# a# p. Q8 zelse 0 E9 {5 ` D! C ; ]# d2 k. ~$ R* q/ L score=’优’;0 B: C) H- u- u& P. Z) S; z9 O
! [5 I% P q2 c) E此判定过程可以用图6.33(a)的判定树来表示。如果学生规模很大,该算法需反复多次执行,就应该考虑算法执行的时间问题。在实际应用中,学生的成绩呈正态分布,大部分在70~89分之间,优秀和不及格的概率较小。假设不及格、及格、中、良、优的百分比为5%、12%、40%、35%、8%,则上述算法80%以上的成绩需要进行三次或三次以上的比较才能得到结果。若以这些百分比值5,12,40,35,8为权值,使用哈夫曼算法来构造一棵判定树,则得到图6.33(b)所示的判定过程,可使多数成绩经过较少的比较即可得到结果。但由于每个判定框都有两次比较,将两次比较分开,得到如图6.33(c)所示的判定树,按此判定树构造程序,显然可以大大减少比较次数。 0 c! S* D" `4 R v2 N4 n# n' s/ Z- C/ }
x x 5 J" q- P( H0 E. N" A ) t7 v2 M- z* M' O7 X- _ 8 h) h/ [( p% W$ Z! R . F* w2 r4 c- t: r# ~, d/ ~* j" L9 E) \* s" C
3 l( n/ F5 c/ e- U x<60 70≤x<80 9 h0 u4 C6 m) E+ j1 Z 2 e# z' k, X3 J Y N Y N ; c& z% S0 d+ u! M% j" ^; D# @5 @9 K
不及格 x<70 中 80≤x<90 b( K, }* _* W; V5 g- J* r# [
: g" X" F# }* V; t
Y N Y N ( V6 Z. r Z$ J' z! ^
R! h% I4 `2 t5 G
及格 x<80 良 60≤x<707 Q3 q# @' m4 I
- }% g( {( n; p' ?; P. S Y N Y N" x& S/ W" @$ T' ^
% l8 k S! @8 g9 e% i" T
中 x<90 x<60 及格 8 t. }4 B8 K* z. Q! F6 Z( L7 l9 R% {
Y N Y N - M( Q+ R- }' t) a6 y. l
% y8 k. r' b0 v) A# G/ o# c& x 良 优 不及格 优 # o; v0 b4 m- l! z6 ?7 x# b/ d$ E G+ S `4 O5 e
(a) (b)/ D* i: s# D1 ^- p! O S8 a, L) N
% {8 p4 R2 Q q9 l( ^
x 2 @) K+ t2 f# b1 b+ l1 k. G8 \4 \! t
3 h0 G& g: e. l$ C- `9 k# |
- P' G* l0 k9 r9 N
x<80 ) i. y$ @1 S) c: k, e # ]5 E; R2 A: G) o5 Z Y3 U5 i: u* W0 p4 h3 T! E7 v
J. F. W% t0 A8 c$ K$ W
x<70 x<90 " l8 ?& O$ d) D* I; W: X' N
2 `: c% T- {; Y. H5 O: OY N Y N 8 D- r1 a9 B( k( U9 a . X- A& q0 N' _! P0 `, T3 _ x<60 中 良 优$ r& ^/ }5 Z+ O
6 r+ e: G( A( q6 P6 X( \ Y N ?" b4 o. W1 P" Y 4 f7 h) _" x3 O0 U* F 不及格 及格" G& `6 l; S% }0 F/ G* X- k
$ D6 ]5 I& _$ ]8 j# ^( Y
(c)) i1 h4 X" M4 q9 `9 w7 W$ m
/ G q0 p8 y9 ~5 w& K* W$ t& n 图6.33 百分制转换五级制的判定过程 . f. C# T8 Q/ V t * w" s% G c! z# e- z, E1 p " V2 e$ b! \' {, x1 }" J5 K2 G+ |# g% C, F z) l: @
哈夫曼树在通信、编码和数据压缩等技术领域也有着广泛的应用。下面我们介绍哈夫曼树在数据编码中的应用,即数据的最小冗余编码问题。 7 y5 P% t$ H* b2 e % Z2 K) H# ~# w) {4 r0 [4 s: _在数据通信中,需要将传送的文字转换成二进制的字符串,用0,1码的不同排列来表示字符。例如,需传送的报文为“AFTER DATA EAR ARE ART AREA”,这里用到的字符集为“A,E,R,T,F,D”,各字母出现的次数为{8,4,5,3,1,1}。现要求为这些字母设计编码。要区别6个字母,最简单的二进制编码方式是等长编码,固定采用3位二进制,可分别用000、001、010、011、100、101对“A,E,R,T,F,D”进行编码发送,当对方接收报文时再按照三位一分进行译码。显然编码的长度取决报文中不同字符的个数。若报文中可能出现26个不同字符,则固定编码长度为5。然而,传送报文时总是希望总长度尽可能短。在实际应用中,各个字符的出现频度或使用次数是不相同的,如A、B、C的使用频率远远高于X、Y、Z,自然会想到设计编码时,让使用频率高的用短码,使用频率低的用长码,以优化整个报文编码。但这样长短不等的编码又会产生一个新问题,即如何解译成原文?除非设计时能够保证任何一个字符的编码都不是同一字符集中另一个字符的编码的前缀,符合此要求的编码称为前缀编码。3 C4 \* j G3 I1 G$ [$ l
/ _4 P. r$ M& x l& ~! N
为使不等长编码为前缀编码,可用字符集中的每个字符作为叶子结点生成一棵编码二叉树,为了获得传送报文的最短长度,可将每个字符的出现频率作为字符结点的权值赋予该结点上,求出此树的最小带权路径长度就等于求出了传送报文的最短长度。因此,求传送报文的最短长度问题转化为求由字符集中的所有字符作为叶子结点,由字符出现频率作为其权值所产生的哈夫曼树的问题。利用哈夫曼树来设计二进制的前缀编码,既满足前缀编码的条件,又保证报文编码总长最短。 $ d5 u, u2 ?* L+ H6 m* k* ?, J6 R 4 p$ @2 ?, s# h2 g) F2 Y我们用上述各字母出现的次数{8,4,5,3,1,1}作为权构造哈夫曼树,如图6.36所示。约定左分支表示字符“0”,右分支表示字符“1”,则可以从根结点到叶子结点的路径的分支上的字符组成的字符串作为该叶子对应字符的编码。可以证明,如此得到的必为二进制前缀编码,而且是一种最优前缀编码。我们称这样的树为哈夫曼编码树,由此得到的编码称为哈夫曼编码。本例中字母A、E、R、T、F、D的哈夫曼编码分别为11、00、01、011、0100、0101。可以看出,出现次数较多的字母A、E、R,具有最短的编码,长度均为2;而出现次数最少的字母F、D,具有最长的编码,长度均为4。报文的最短传送长度为: & t8 z) U2 ]* K% _0 t. J
" o, d) j3 e# W( e, Z 67 B) { p/ X3 |9 t+ ^0 A" Y
8 a T) q' c- s$ r$ ? L=WPL=S(wklk)=4×2+5×2+8×2+3×3+1×4+1×4=51 5 ^: |! u# m# w$ F* e# G0 ] l2 r* @6 O6 E: D
k=1 5 ~* P! Y( m: q+ W! ~% h; T' U2 \2 V+ V* w9 h8 J" N3 z' Y6 U7 @- c
若采用等长编码,报文的传送长度为 ! _2 p6 {7 I9 Q% w) }0 G* _/ i
8 g# h. A4 v! j; B. e
L=8×3+4×3+5×3+3×3+1×3+1×3=663 q3 e: S3 t1 d/ I' d) [