离散数学 第九章:树

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

课后作业:9.13
树的遍历:
行遍(周游)根树T : 对T 的每个顶点访问且仅访问一次. 行遍2元有序正则树的方式: ① 中序行遍法: 左子树、根、右子树 ② 前序行遍法: 根、左子树、右子树 ③ 后序行遍法: 左子树、右子树、根
例如, 对图所示根树按中序、前序、 后序行遍法访问结果分别为: b a (f d g) c e a b (c (d f g) e) b ((f g d) e c) a 带下划线的是(子)树根, 一对括号内是一棵子树
9.2
一、树的概念
根树及其应用
有向树: 基图为无向树的有向图 根树: 有一个顶点入度为0, 其余的入度均为1的 非平凡的有向树 树根: 有向树中入度为0的顶点 树叶: 有向树中入度为1, 出度为0的顶点 内点: 有向树中入度为1, 出度大于0的顶点 分支点: 树根与内点的总称(出度大于等于1) 顶点v的层数: 从树根到v的通路长度,记作l(v) 树高: 有向树中顶点的最大层数,记作h(T)
定义 设2元树T有t片树叶v1, v2, …, vt, 树叶的权分别
为w1, w2, …, wt, 称 W ( t ) wi l ( vi ) 为T的权, 记作
t i 1
W(T), 其中l(vi)是vi的层数. 在所有有t片树叶, 带权
w1, w2, …, wt 的 2元树中, 权最小的2元树称为最优
例9.1.3:
Ca=aef
b d e f c
Cb=bde
Cc=cdf
a
基本回路系统为:{Ca, Cb, Cc}= { aef , bde , cdf }
每条弦对应一个基本回路。是由该条弦和树枝构成的回路。
六:★基本割集与基本割集系统
定义: 设T是n阶连通图G的一棵生成树, e1, e2, …, en1为T的树枝,Si是G的只含 树枝ei, 其他边都是弦的割集, 称Si为 对应生成树T由树枝ei生成的基本割 集。(集合) i=1, 2, …, n1. 称{S1, S2, …, Sn1}为对应T的基 本割集系统.(集合的集合) (共有n-1条树枝,每条树枝有一个基本割集)
例9.1.b d e
Sc={c,f,h} Sd={d,h,i}
Se={e,f,i}
g h i
基本割集系统为:{Sa, Sb, Sc , Sd, Se} 每条树枝对应一个基本割集.由该条树枝和弦构成的边割集
课后例题:9.6,9.7,9.8 课后作业:9.1,9.3,9.4,9.6,9.7,9.8
霍夫曼树是不唯一的!
例9.2.1:
例 求带权为1, 1, 2, 3, 4, 5的最优树. 解题过程由下图给出,W(T)=38
前缀码:
设 =12…n-1n是长度为n的符号串 的前缀: 12…k , k=1,2,…,n-1 前缀码: {1, 2, …, m}, 其中1, 2, …, m为非空字符 串, 且任何两个互不为前缀 2元前缀码: 只出现两个符号(如0与1)的前缀码 如 {0,10,110, 1111}, {10,01,001,110}是2元前缀码 {0,10,010, 1010} 不是2元前缀码 课后习题:9.9
9.1
一、树的概念
无向树及生成树
树:连通而不含回路的无向图称为无向树, 简称树,记作 T。 森林:连通分支数大于等于2,且每个连通
分支均是树的非连通无向图。
平凡树:平凡图为平凡树。 树叶: 树中度数为1的顶点 分支点: 树中度数2的顶点
森林
树的性质: 设G=<V,E>是n阶m条边的无向树, 则下面各命题是等价的: (1) G连通而不含回路;
生成树的余树不一定是树
四、★最小生成树
带权图的最小生成树:设G = < V,E,W >是带权
的连通简单图, T是G的一棵生成树, T中所有枝的权之和称为T的权,记作:
W(T)。
具有权最小的生成树称为最小生成树。
方法:避圈法(克鲁斯卡尔算法)
在不产生回路的基础上依次画出 权值最小的边,直至画出n-1条边 为止
根树的画法:树根放上方,省去所有有向边上的箭头 如右图所示 a是树根 b,e,f,h,i是树叶 c,d,g是内点 a,c,d,g是分支点 a为0层;1层有b,c; 2层有d,e,f; 3层有g,h; 4层有i. 树高为4
家族树:
定义 把根树看作一棵家族树: (1) 若顶点 a 邻接到顶点 b, 则称 b 是 a 的儿子, a 是 b 的父亲; (2) 若b和c为同一个顶点的儿子, 则称b和c是 兄弟; (3) 若ab且a可达b, 则称a是b的祖先, b是a的 后代. (4)设v为根树的一个顶点且不是树根, 称v及其 所有后代的导出子图为以v为根的根子树.
根树的分类: 有序树: 每一层的结点均有序 r元树:根树的每个分支点至多有r个儿子 r元正则树: 根树的每个分支点恰有r个儿子 r元完全正则树: 所有树叶层数相同都等于树高的r元 正则树 r元有序树: 有序的r元树 r元正则有序树: 有序的r元正则树 r元完全正则有序树: 有序的r元完全正则树
最优二元树:
2元树.
Huffman算法 给定实数w1, w2, …, wt,
① 作t片树叶, 分别以w1, w2, …, wt为权.并将其从小 到大排列。
② 在所有入度为0的顶点(不一定是树叶)中选出两个 权最小的顶点, 添加一个新分支点, 以这2个顶点为 儿子, 其权等于这2个儿子的权之和.
③ 重复②, 直到只有1个入度为0 的顶点为止. W(T)等于所有分支点的权之和
例9.3:
例 在通信中,设八进制数字出现的频率如下:
0:30% 4:10% 1:20% 5:5% 2:15% 6:5% 3:10% 7:5%
采用2元前缀码, 求传输数字最少的2元前缀码 (称作 最佳前缀码), 并求传输10000个按上述比例出现的 八进制数字需要多少个二进制数字? 解 : 用Huffman算法求以频率(乘以100)为权的最优2 元树.
应用:算术式的波兰符号法与逆波兰符号法 用2元有序正则树表示算式: 最高层次运算放在树 根上, 然后依次将运算符放在根子树的根上, 数放 在树叶上, 规定被除数、被减数放在左子树树叶上.
例如, 右图表示算式 ((b+(c+d))a)((ef)(g+h)(ij))
波兰符号法(前缀符号法): 按前序法遍历算式树, 其 结果不加括号. 例如, 对上页中树的访问结果为 b+cdaef+ghij 逆波兰符号法(后缀符号法): 按后序法遍历, 规定每 个运算符与前面紧邻两数运算. 例如, 对上页中树的访问结果为 bcd++aefgh+ij
小结与学习要求
1.重要知识点:最小生成树,基本回路系统,
基本割集系统,最优二元树(霍夫曼树),最优编
码,树的遍历,波兰及逆波兰表达式。
2.了解树的基本定义,有序树的基本概念。
作业六
课后习题:
9.1,9.7,9.8,9.11,9.13
(2) 每对顶点之间具有唯一一条初级通路
(3) ★n = m+1 (4) 若在G中任意两个不相邻的顶点之间增加一 条边,就形成唯一一条初级回路。 (5) 连通且每条边都是桥 (6) 连通但删除任何一条边后就不连通
性质(7): 任一棵非平凡树 T = < V,E >,至少有 两片叶。 证明:设T有x片树叶,由握手定理及定理9.1知,
由上式解出x2.
三、生成树及其构造方法
生成树:若图G为无向连通图. T为G的生成子
图,且T为树,称T为G的生成树。 树枝与弦:G在T中的边称为T的树枝,G不
在T中的边称为T的弦。 余树:T的弦的集合的导出子图称为T的余树。
例子
A
A
A
生成树
D B C
余树
D
B
B
C
C
生 成 树
A
余树
D
D
B
B C
C
无向连通图的生成树不一定唯一
树的编码:
一棵2元树产生一个二元前缀码: 对每个分支点, 若关联2条边, 则给左边标0, 右边标1; 若只关联1条边, 则可以给它标0(看作左边), 也可以 标1(看作右边). 将从树根到每一片树叶的通路上标 的数字组成的字符串 记在树叶处, 所得的字符 串构成一个前缀码. 如右图所示: 最优2进制编码:使信息传 递的2进制数最短
例9.1.1: v1
v1 5
5
v2 1 v6 6 4 6 5
v5
2 v4
v2
3 v3 5
1 v6 4 2 v4
v5
3
v3
5
W(T)=1+2+3+4+5=15
例9.1.2: 5 v2 3 v3 5 5
!最小生成树不一定唯一
v1 5 1 v6 5 v5 v2 1 5 v6 5 2 v4 v5 v1
6 5
6
2
v4
3 v3
or
v2 3 v3
1 v6
5 2
v4
v5
or
v2 3 v3
1
5
v6 5 2
v5
v4
W(T)=1+2+3+5+5=16
五:★基本回路与基本回路系统
定义: 设T是n阶m条边的无向连通图G的一棵 生成树,设e1, e2, … , emn+1为T的弦. 设Cr为T添加弦er产生的G中惟一的圈 (由er和树枝组成), 称Cr为对应弦er的 基本回路。(路径) r=1, 2, …, mn+1. 称{C1,C2, …, Cmn+1}为对应T 的基本回路系统.(路径的集合) (共有m-n+1条弦,每条弦有一个基本回路)
相关文档
最新文档