第6章二叉树课练答案.docx

上传人:b****4 文档编号:5971305 上传时间:2023-05-09 格式:DOCX 页数:10 大小:52.14KB
下载 相关 举报
第6章二叉树课练答案.docx_第1页
第1页 / 共10页
第6章二叉树课练答案.docx_第2页
第2页 / 共10页
第6章二叉树课练答案.docx_第3页
第3页 / 共10页
第6章二叉树课练答案.docx_第4页
第4页 / 共10页
第6章二叉树课练答案.docx_第5页
第5页 / 共10页
第6章二叉树课练答案.docx_第6页
第6页 / 共10页
第6章二叉树课练答案.docx_第7页
第7页 / 共10页
第6章二叉树课练答案.docx_第8页
第8页 / 共10页
第6章二叉树课练答案.docx_第9页
第9页 / 共10页
第6章二叉树课练答案.docx_第10页
第10页 / 共10页
亲,该文档总共10页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

第6章二叉树课练答案.docx

《第6章二叉树课练答案.docx》由会员分享,可在线阅读,更多相关《第6章二叉树课练答案.docx(10页珍藏版)》请在冰点文库上搜索。

第6章二叉树课练答案.docx

第6章二叉树课练答案

第6章树和二叉树

一、下面是有关二叉树的叙述,请判断正误

(√)1.若二叉树用二叉链表作存贮结构,则在n个结点的二叉树链表中只有n-1个非空指针域。

n个结点的二叉树有n-1条分支

(×)2.二叉树中每个结点的两棵子树的高度差等于1。

(√)3.二叉树中每个结点的两棵子树是有序的。

(×)4.二叉树中每个结点有两棵非空子树或有两棵空子树。

(×)5.二叉树中每个结点的关键字值大于其左非空子树(若存在的话)所有结点的关键字值,且小于其右非空子树(若存在的话)所有结点的关键字值。

(应当是二叉排序树的特点)

(×)6.二叉树中所有结点个数是2k-1-1,其中k是树的深度。

(应2k-1)

(×)7.二叉树中所有结点,如果不存在非空左子树,则不存在非空右子树。

(×)8.对于一棵非空二叉树,它的根结点作为第一层,则它的第i层上最多能有2i-1个结点。

(应2i-1)

(√)9.用二叉链表法(link-rlink)存储包含n个结点的二叉树,结点的2n个指针区域中有n+1个为空指针。

(用二叉链表存储包含n个结点的二叉树,结点共有2n个链域。

由于二叉树中,除根结点外,每一个结点有且仅有一个双亲,所以只有n-1个结点的链域存放指向非空子女结点的指针,即有后继链接的指针仅n-1个,还有n+1个空指针。

采用二叉链表存储有2n个链域,空链域为:

2n-(n-1)=n+1

(√)10.具有12个结点的完全二叉树有5个度为2的结点。

最快方法:

用叶子数=[n/2]=6,再求n2=n0-1=5

[n/2]除的结果四舍五入

二、填空

1.由3个结点所构成的二叉树有5种形态。

2.一棵深度为6的满二叉树有n1+n2=0+n2=n0-1=31个分支结点和26-1=32个叶子。

注:

满二叉树没有度为1的结点,所以分支结点数就是二度结点数。

(或:

总结点数为n=2k-1=26-1=63,叶子数为n0=[n/2]=32,满二叉数没有度为1的结点,由n0=n2+1得n2=n0-1=32-1=31)

3.一棵具有257个结点的完全二叉树,它的深度为9。

(注:

用log2(n)+1=8.xx+1=9

证明:

根据性质2,深度为k的二叉树至多有2k-1个结点。

最小的一棵完全二叉树的结点数:

(2k-1-1)+1=2k-1

最大的一棵完全二叉树(满二叉树)的结点数:

(2k-1)

则:

2k-1<=n<2k,取对数:

k-1<=log2n

k=log2(n)+1

4.一棵完全二叉树有700个结点,则共有350个叶子结点。

答:

最快方法:

用叶子数=[n/2]=350

5.设一棵完全二叉树具有1000个结点,则此完全二叉树有500个叶子结点,有499个度为2的结点,有1个结点只有非空左子树,有0个结点只有非空右子树。

答:

最快方法:

用叶子数=[n/2]=500,n2=n0-1=499。

另外,最后一结点为2i属于左叶子,右叶子是空的,所以有1个非空左子树。

完全二叉树的特点决定不可能有左空右不空的情况,所以非空右子树数=0.

6.一棵含有n个结点的k叉树,可能达到的最大深度为n,最小深度为2。

答:

当k=1(单叉树)时应该最深,深度=n(层);当k=n-1(n-1叉树)时应该最浅,深度=2(层),但不包括n=0或1时的特例情况。

7.二叉树的基本组成部分是:

根(N)、左子树(L)和右子树(R)。

因而二叉树的遍历次序有六种。

最常用的是三种:

前序法(即按DLR次序),后序法(即按LRD次序)和中序法(也称对称序法,即按LDR次序)。

这三种方法相互之间有关联。

若已知一棵二叉树的前序序列是BEFCGDH,中序序列是FEBGCHD,则它的后序序列必是FEGHDCB。

解:

法1:

先由已知条件画图,再后序遍历得到结果;

法2:

不画图也能快速得出后序序列,只要找到根的位置特征。

由前序先确定root,由中序先确定左子树。

例如,前序遍历BEFCGDH中,根结点在最前面,是B;则后序遍历中B一定在最后面。

法3:

递归计算。

如B在前序序列中第一,中序中在中间(可知左右子树上有哪些元素),则在后序中必为最后。

如法对B的左右子树同样处理,则问题得解。

8.用5个权值{3,2,4,5,1}构造的哈夫曼(Huffman)树的带权路径长度是33。

解:

先构造哈夫曼树,得到各叶子的路径长度之后便可求出WPL=(4+5+3)×2+(1+2)×3=33

(15)

(9)(6)

453(3)

12

三、单项选择题

(C)1.不含任何结点的空树。

(A)是一棵树;(B)是一棵二叉树;

(C)是一棵树也是一棵二叉树;

(D)既不是树也不是二叉树

答:

以前的标答是B,因为那时树的定义是n≥1

(C)2.二叉树是非线性数据结构,所以。

(A)它不能用顺序存储结构存储;

(B)它不能用链式存储结构存储;

(C)顺序存储结构和链式存储结构都能存储;

(D)顺序存储结构和链式存储结构都不能使用

(C)3.具有n(n>0)个结点的完全二叉树的深度为。

(A)log2(n)(B)log2(n)

(C)log2(n)+1(D)log2(n)+1

注1:

x表示不小于x的最小整数;x表示不大于x的最大整数,它们与[]含义不同!

(四舍五入)

注2:

选(A)是错误的。

例如当n为2的整数幂时就会少算一层。

log2(n+1)是正确的。

(A)4.把一棵树转换为二叉树后,这棵二叉树的形态是。

(A)唯一的(B)有多种

(C)有多种,但根结点都没有左孩子

(D)有多种,但根结点都没有右孩子

四、简答题(每小题4分,共20分)

1.一棵度为2的树与一棵二叉树有何区别?

答:

度为2的树从形式上看与二叉树很相似,但它的子树是无序的,而二叉树是有序的。

即,在一般树中若某结点只有一个孩子,就无需区分其左右次序,而在二叉树中即使是一个孩子也有左右之分。

2.给定二叉树的两种遍历序列,分别是:

前序遍历序列:

D,A,C,E,B,H,F,G,I;

中序遍历序列:

D,C,B,E,H,A,G,I,F,

试画出二叉树B,并简述由任意二叉树B的前序遍历序列和中序遍历序列求二叉树B的思想方法。

解:

方法是:

由前序先确定root,由中序可确定root的左、右子树。

然后由其左子树的元素集合和右子树的集合对应前序遍历序列中的元素集合,可继续确定root的左右孩子。

将他们分别作为新的root,不断递归,则所有元素都将被唯一确定,问题得解。

D

A

CF

EG

BHI

 

五、阅读分析题

1.试写出如图所示的二叉树分别按先序、中序、后序遍历时得到的结点序列。

答:

DLR:

ABDFJGKCEHILM

LDR:

BFJDGKACHELIM

LRD:

JFKGDBHLMIECA

2.把如图所示的树转化成二叉树。

答:

注意全部兄弟之间都要连线(包括度为2的兄弟),并注意原有连线结点一律归入左子树,新添连线结点一律归入右子树。

A

B

EC

KFHD

LGI

MJ

 

4.画出和下列二叉树相应的森林。

答:

注意根右边的子树肯定是森林,而孩子结点的右子树均为兄弟。

5.假设用于通信的电文仅由8个字母组成,字母在电文中出现的频率分别为0.07,0.19,0.02,0.06,0.32,0.03,0.21,0.10。

试为这8个字母设计哈夫曼编码。

使用0~7的二进制表示形式是另一种编码方案。

对于上述实例,比较两种方案的优缺点。

解:

方案1;哈夫曼编码

先将概率放大100倍,以方便构造哈夫曼树。

w={7,19,2,6,32,3,21,10},按哈夫曼规则:

01

0101

192132

11

0101

7106

11

23

(100)

(40)(60)

192132(28)

(17)(11)

7106(5)

23

 

方案比较:

字母编号

对应编码

出现频率

1

000

0.07

2

001

0.19

3

010

0.02

4

011

0.06

5

100

0.32

6

101

0.03

7

110

0.21

8

111

0.10

字母编号

对应编码

出现频率

1

1100

0.07

2

00

0.19

3

11110

0.02

4

1110

0.06

5

10

0.32

6

11111

0.03

7

01

0.21

8

1101

0.10

 

方案1的WPL=

2(0.19+0.32+0.21)+4(0.07+0.06+0.10)+5(0.02+0.03)=1.44+0.92+0.25=2.61

方案2的WPL=

3(0.19+0.32+0.21+0.07+0.06+0.10+0.02+0.03)=3

结论:

哈夫曼编码优于等长二进制编码

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 工程科技 > 能源化工

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2