41、分别画出具有3个结点的树和3个结点二叉树的所有不同形态.
42、一个深度为L的满K叉树有如下性质:第L层上的结点是叶子结点,其余各层上每个结点都有K棵非空子树,如果按层次顺序从1开始对全部结点编号,问:
(1) 各层的结点的数目是多少?
(2) 编号为n的结点的双亲结点(若存在)编号是多少?
(3) 编号为n的结点的第i个孩子(若存在)编号是多少?
(4)编号为n的结点有右兄弟的条件是什么?其右兄弟的编号是多少?
43、若二叉树用二叉链表作存贮结构,则在n个结点的二叉树链表中只有n—1个非空指针域。(
44、二叉树中每个结点的两棵子树的高度差等于1。(
45、二叉树中每个结点的两棵子树是有序的。(
46、二叉树中每个结点有两棵非空子树或有两棵空子树。(
47、二叉树中每个结点的关键字值大于其左非空子树(若存在的话)所有结点的关键字值,且小于其右非空子树(若存在的话)所有结点的关键字值。
48、二叉树中所有结点个数是2k-1-1,其中k是树的深度。(
49、二叉树中所有结点,如果不存在非空左子树,则不存在非空右子树。(
50、对于一棵非空二叉树,它的根结点作为第一层,则它的第i层上最多能有2i—1个结点。(
51、用二叉链表法(link-rlink)存储包含n个结点的二叉树,结点的2n个指针区域中有n+1个为空指针。(
52、具有12个结点的完全二叉树有5个度为2的结点。(
53、由3个结点所构成的二叉树有
54、一棵深度为6的满二叉树有
注:满二叉树没有度为1的结点,所以分支结点数就是二度结点数。
55、棵具有257个结点的完全二叉树,它的深度为
56、设一棵完全二叉树有700个结点,则共有
57、设一棵完全二叉树具有1000个结点,则此完全二叉树有
58、一棵含有n个结点的k叉树,可能达到的最大深度为
59、二叉树的基本组成部分是:根(N)、左子树(L)和右子树(R)。因而二叉树的遍历次序有六种。最常用的是三种:前序法(即按N L R次序),后序法(即按
60、中序遍历的递归算法平均空间复杂度为
61、用5个权值{3, 2, 4, 5, 1}构造的哈夫曼(Huffman)树的带权路径长度是
62、不含任何结点的空树(
A、是一棵树;
C、是一棵树也是一棵二叉树;
63、二叉树是非线性数据结构,所以(
A、它不能用顺序存储结构存储;
C、顺序存储结构和链式存储结构都能存储;
64、具有n(n>0)个结点的完全二叉树的深度为(
65、把一棵树转换为二叉树后,这棵二叉树的形态是(
A、唯一的
C、有多种,但根结点都没有左孩子
66、树是结点的有限集合,它(
的集合T1,T2,…,Tm,每个集合又都是树,此时结点T称为Ti的父结点,Ti称为T的子结点(1≤i≤m)。一个结点的子结点个数为该结点的(
供选择的答案
A:
B:
C: ①权
67、二叉树(
供选择的答案
A: ①是特殊的树
B:
C~D: ①最左子结点
68、一棵度为2的树与一棵二叉树有何区别?
69、设如下图所示的二叉树B的存储结构为二叉链表,root为根指针,结点结构为:(lchild,data,rchild)。其中lchild,rchild分别为指向左右孩子的指针,data为字符型,root为根指针,试回答下列问题:
(1)
(2)
二叉树B
C的结点类型定义如下:
struct node
{char data;
struct node *lchild, rchild;
};
C算法如下:
void traversal(struct node *root)
{if (root)
traversal(root->rchild);
}
}
70、给定二叉树的两种遍历序列,分别是:
前序遍历序列:D,A,C,E,B,H,F,G,I;
试画出二叉树B,并简述由任意二叉树B的前序遍历序列和中序遍历序列求二叉树B的思想方法。
71、给定如图所示二叉树T,请画出与其对应的中序线索二叉树。
72、试写出如图所示的二叉树分别按先序、中序、后序遍历时得到的结点序列。
73、把如图所示的树转化成二叉树。
74、画出和下列二叉树相应的森林。
75、编写递归算法,计算二叉树中叶子结点的数目。
提示:输出叶子结点比较简单,用任何一种遍历递归算法,凡是左右指针均空者,则为叶子,将其打印出来。
76、写出求二叉树深度的算法,先定义二叉树的抽象数据类型。
设计思路:只查后继链表指针,若左或右孩子的左或右指针非空,则层次数加1;否则函数返回。但注意,递归时应当从叶子开始向上计数,否则不易确定层数。
77、编写按层次顺序(同一层自左至右)遍历二叉树的算法。(或:按层次输出二叉树中所有结点;)
提示:既然要求从上到下,从左到右,则利用队列存放各子树结点的指针是个好办法。
这是一个循环算法,用while语句不断循环,直到队空之后自然退出该函数。
技巧之处:当根结点入队后,会自然使得左、右孩子结点入队,而左孩子出队时又会立即使得它的左右孩子结点入队,……以此产生了按层次输出的效果。
78、编写算法判别给定二叉树是否为完全二叉树。
79、假设用于通信的电文仅由8个字母组成,字母在电文中出现的频率分别为0.07,0.19,0.02,0.06,0.32,0.03,0.21,0.10。试为这8个字母设计哈夫曼编码。使用0~7的二进制表示形式是另一种编码方案。对于上述实例,比较两种方案的优缺点。