数据结构期末复习题汇总
科技手抄报-保险公司演讲稿
(1)若以1234作为双端队列的输入序列,则既不能由输入受限双端队列得到,也不能由输出
受限双端队列
得到的输出序列是( )。
A
)
1234
B
)
4132 C
)
4231
D
)
4213
(
2
)将一个
A[1..100,1..1
00]
的三对角矩阵,按行优先存入一维数组
B[298]
中,
A
中
元素
a
66,65
在
B
数组
B
)
195 C
)
197
中的位置
k
为(
)(假设
B[0]
的位置是
1
)。
A
)
198
D
)
198
(
3
)若度为
m
的哈
夫曼树中,其叶结点个数为
n
,则非叶结点的个数为( )。
A
)
n-1 B
)
n
1
m
C
)
n1
m1
D
)
n
1
m1
(
4
)若一个有向图具有拓扑排序序列,并且顶点按拓扑排序序列编号,那么它的邻接矩阵必定为
(
)。
A
)对称矩阵
B
)稀疏矩阵
C
)三角矩阵
D
)一般矩阵
(
5
)设森林
F
对应的二叉树为有
m
个结点,
此二叉树根的左子树的结点个数为
k
,则另一棵子树的结
点个数为(
)。
A
)
m-k+1 B
)
k+1
C
)
m-k-1 D
)
m-k
(
6
)假定有<
br>K
个关键字互为同义词,若用线性探测法把这
K
个关键字存入散列表中,至少要
进行( )
次探测。
A
)
K-1
次
B
)
K
次
C
)
K
+
l
次
D
)
K(K+1)2
次
(
7
)一棵
深度为
k
的平衡二叉树,其每个非终端结点的平衡因子均为
0
,则该树共有(
)个结点。
A
)
2
k-1
-1
B
)
2
k-1
C
)
2
k-1
+1
D
)
2
k
-1
(
8
)如表
r
有
100000
个元素,前
99999
个元素递增有序,则采用(
)方法比较次数较少。
A
)直接插入排序
B
)快速排序
C
)归并排序
D
)选择排序
(
9
)如果只考虑有序树的情形,那么具有
7
个结点的不同形态的树共有(
)棵。
A)132 B)154 C)429 D)前面均不正确
(
10
)对
n(n>=2)
个权值均不相同的字符构成哈夫曼树,关于该树的叙
述中,错误的是(
)。
A
)该树一定是一棵完全二叉树
B
)树中一定没有度为
1
的结点
C
)树中两个权值最小的结点一定是兄弟结点
D
)树中任一非叶结点的权值一定不小于下一任一结点的权值
二、(本题8分)
斐波那契数列
Fn
定义如下:
F0
=0
,
F
1
=1
,
F
n
=
F
n-1
+F
n-2
请就此斐波那契数列,回答下列问题:
(
1
)在递归计算
F
n
的时候,需要对较小的
F
n-1
,
F
n-2<
br>,…,
F
1
,
F
0
精确计算多少次?
(
2
)若用有关大
O
表示法,试给出递归计算
Fn
时递
归函数的时间复杂度是多少?
三、(本题8分)
证明:如果一棵二叉树的后序序列
是
u
1
,
u
2
,
…
,
u
n
,中序序列是
u
p
,
u
p
,
…
,
u
p
,则由序列
1,2,
…
,n
可通
1
2n
过一个栈得到序列
p
1
,
p
2
,
…<
br>,
p
n
。
四、(本题8分)
如下图所示为
5
个乡镇之间的交通图,乡镇之间道路的长度如图中边上所注。现在要在这
5
个乡镇
中选
择一个乡镇建立一个消防站,问这个消防站应建在哪个乡镇,才能使离消防站最远的乡镇到消防站的
路程最
短。试回答解决上述问题应采用什么算法,并写出应用该算法解答上述问题的每一步计算结果。
1
3
5
6
4
9
4
12
2
6
3
五、(本题8分)
证明一个深度为
n
的
A
VL
树中的最少结点数为:
Nn=F
n+2
-1
(n
≥
0)
其中,
Fi
为
Fibonacci
数
列的第
i
项。
六、(本题8分)
简单回答有关
AVL
树的问题:(北方名校经典试题)
(
1
)在有
n
个结点的
AVL
树中,为结点增加
一个存放结点高度的数据成员,那么每一个结点需要增加
多少个字位(
bit
)?
(
2
)若每一个结点中的高度计数器有
8bit
,那么这样的
AVL
树可以有多少层?最少有多少个关键字?
七、(本题8分)
设有
12
个数据
{25
,
40
,
33<
br>,
47
,
12
,
66
,
72
,87
,
94
,
22
,
5
,
58},它们存储在散列表中,利用线性探测再
散列解决冲突,要求插入新数据的平均查找次数不超过3
次。
(
1
)该散列表的大小
m
应设计多大?
(
2
)试为该散列表设计相应的散列函数。
(
3
)顺次将各个数据散列到表中。
(
4
)计算查找成功的平均查找次数。
八、(本题8分)
已知某电文中共出现了
10
种不同的字母,每个字母出现的频率分别为
A
:
8
,
B
:
5
,
C
:
3
,
D
:
2
,
E
:
7
,
F
:
23
,
G
:
9
,
H
:
11
,
I
:
2
,
J
:
35
,现在对这段电文
用三进制进行编码(即码字由
0
,
l
,
2
组成),问
电文编码总长度至少有多少位?请画出相应的图。
九、(本题9分)
已知一棵
度为
m
的树中有
N
1
个度为
1
的结点,
N
2
个度为
2
的结点,…,
N
m
个度为
m<
br>的结点。试问该
树中有多少个叶子结点?(北方名校经典试题)
十、(本题15分)
试用递归法编写输出从
n
个数中挑选
k
个进行排列所得序列的算法。
模拟试题(七)参考答案
一、单项选择题(每小题 2 分,共20分)
(
1
)参考答案:
C
)
(
2
)
【分析】如下所示,三对角矩阵第
1
行和最后
1
行非零元素个数为
2
个,其余各行的非零元素个数是
3
个,所知
a
66,65
前
面共有
2+3*64
=
194
个非零元素,
a
66,65<
br>本身是第
195
个非零元。
a
11
a
21
A
a23
a
33
a
34
a
n2,n
1
a
n2,n2
a
n1,n
a
n2,
n1
a
n1,n1
a
n,n1
a
n1,n
a
nn
a
12
a
22
a
3
2
参考答案:
B
)
(
3
)【分析】在哈夫曼树的
非叶结点中最多只有
1
个结点的度不为
m
,设非叶结点的个数为
k<
br>,则其中
有
k-1
个结点的度为
m
,设另
1
个结点的度为
u
,则
2
≤
u
≤
m
,设结点
总数为
n
总
,则有如下关系:
n
总
-1=m(k-1)+u
①
n
总
=k+n
②
将②代入①可得:
k+n-1= m(k-1)+u
,解得:
k
(
n1)(mu)
,由于
2
≤
u
≤
m
,所以可
得
0
≤
m-u
m1
<
m-1
,所以可得:
n1n1
n1
+1
,可知
k
≤k
<。
m1m1
m1
参考答
案:
C
)
(
4
)【分析】设顶点按拓扑排序序列为:v
0
,v
1
,…,v
n-1
,则对于邻接矩阵
A
,只有当
i
<
v
i
,v<
br>j
>
,也就是当
i>j
时,一定没有弧
< v
i,v
j
>
,所以这时
A[i][j]=0
,可知邻接矩阵为三角
矩阵。
参考答案:
C
)
(
5
)【分析】设另一棵子树的结点个数为
n
,所以有
m=n+k+1
,可知
n= m-k-l
。
参考答案:
C
)
(
6
)【分析】因为
K
个关键字互为同义词,只有在存入第一个关键字的情况下不发生冲突,所以至少
需进行
1+2+
…
+K=K(K+1)2
次探测。
参考答案:
D
)
(
7
)【分析】由于每个非终端
结点的平衡因子均为
0
,所以每个非终端结点必有左右两个孩子,且左子
树的高度和右
子树的高度相同,这样
AVL
树是满二叉树。高度为
k
的满二叉树的结点数为
2
k
-l
。
参考答案:
D
)
(
8
)【分析】本题中只有直接插入排序利用前面有序的子序列这个性质,如用直接插
入排序对本题只需将最
后一个元素插入到前面
99999
个元素的有序子序列中即可,
显然比较次数较少。
参考答案:
A
)
(
9)【分析】具有
n
个结点有不同形态的树的数目和具有
n-l
个结点互不
相似的二叉树的数目相同(将
树转化为二叉树时,根结点右子树为空,所以除根结点而外只有左子树,其
不相似的二叉树的等价于不相似
的左子树)。具有
n
个结点互不相似的二又树的数目为
参考答案:
A
)
(
10
)参考答案:
A
)
二、(本题8分)
【解答】
1
1
n
6
C
2
C12
132
。
n
,本题中应为
n1
61
(
1
)设在计算
F
n
时,由
F
n-1+F
n-2
可知
F
n-1
要精确计算
1
次;<
br>
由
F
n-1
=F
n-2
+F
n-3
可知
F
n
=2F
n-2
+F
n-3
,
F
n-2
要精确计算
2
次;
由
F
n-2<
br>=F
n-3
+F
n-4
可知
F
n
=3Fn-3
+2F
n-4
,
F
n-3
要精确计算
3
次,
F
n
=3F
n-3
+2F
n-4
公式
中
F
n-3
的系数为
F
n-3
要精确
F
n
=a
j
*F
n-j
+a
j-1
*F
n-j
-1
。
计算次数,而
F
n-4
的系数为
F
n-2
要精确计算次数,以此类推,设
F
n-j
的精确计算次为
a
j
,则有:
由
F
n-j
=F
n-j-1
+
F
n-j-2
可知
F
n
=(a
j
+ a
j
-1
)*F
n-j-1
+a
j
*F
n-j-2
<
br>,
F
n-j-1
的精确计算次数为
a
j+1
,所以有
:
a
j+1
=a
j
+a
j-1
F
n-2
,
F
1
,
F
0
的精确计算次为
:
1
,
2
,
3
,
5
,由于
Fn-1
要精确计算
a
1
为
1
次,即
a
1
=1
,即可知
F
n-1
,…,……,
a
j
=a
j-1
+a
j-2
……
与斐波那契数列数列:
0
,
1
,
2
,<
br>3
,
5
,……,
F
n
=F
n-1
+
F
n-2
……
比较可知
a
j
=F
j+1
。
(
2
)由于
F
n
的计算最终要转化为
F
0
与
F
1
之和,其加法的计算次数为
F
0
与
F
1
的精确计算次数之和再减
1
之差,由于
F
0
=F
n-n<
br>与
F
1
=F
n-(n-1)
,所以计算
F
n
时,加法计算次数为:
a
n
+a
n-1
-1=F
n+1
+F
n
-1
由于
Fn=
115
n
115
n
15
n
()()
,可知时间复杂度为<
br>O(
()
)
。
22
2
55
三、(本题8分)
【解答】当
n=1
时,结论显然成立。
设
n<=k
时结论成立,当
n=k+1
时,设一棵二叉树的后序序列是
u
1
,
u
2
,
…
,
u
n
,中序序列是
u
p
,
u
p
,
…
,
u
p
,
12n
{
u
p
,
u
p
,
…
,
u
p
}
可知
u
n
是二叉树的根结点,设p
j
n
,可知
{
u
p
,
u
p
,
…
,
u
p
}
是左子树的结点集合,
1
2n
j1j1j2
是右子树的结点集合,进一步可知:
(
1
)左子树的后序序列是
u
1
,
u
2
,
…<
br>,
u
j1
,中序序列是
u
p
,
u
p
,
…
,
u
p
,由归纳假设知序列
1,2,
…
,j-1
12
j1
可以通过一个栈得序列
p
1
,
p
2
,
…
,
p
j1
。
<
br>(
2
)右子树的后序序列是
u
j
,
u
j1
,
…
,
u
n1
,中序序列是
u
p,
u
p
,
…
,
u
p
,设
u
1
…,
u
j
,
u
j1
,
u
2
n
j1j2
j
u
n1
;
u
p
1
p
j1
j1
,
p
2
p
j2
j1
,…,
u
n
u
p
j2
,…,
u
p
nj
u
p
n
,则
p
1
u
p
j1
,
u
p
2
,
p
2
,…,
p
n
j
p
n
j1
,由归纳假设知序列
1,2,
…,n-j
可以通过一个栈得序列
p
1
j
,显然按同
样的
p
n
方式,
j,j+1,
…
,n-1 可以通过一个栈得序列
j1p
1
,
j1p
2
,
…
,
j1p
n
j
,
也就是
p
j1
,
p
j2
,…,
p
n<
br>。
由(
1
)(
2
)及
p
j
n可知由
1,2,
…
,n
可通过一个栈得到序列
p
1,
p
2
,
…
,
p
n
。由数学归纳法可
知本题结
论成立。
四、(本题8分)
012
120
96
3
9
6
0
4
4
0
6
4
0
6
【解答】由弗洛伊德(
Floyd
)算法进行求解,具体步骤如下:
3
0129
120
6
,
(0)
D
960
6
4
0
31512
4
0
6
3
15
;
12
6<
br>
0
D
(1)
D
(1)
<
br>0129
1206
960
4
31512
3
0129133
120
15
,
61015
;
(2)
12
D
960412
6
13104
06
0
0
315
126
D
(3)
93
0129133
0129
120
120
61015
61015
,
。
(4
)
960412
D
960410
1310406
910406
0
0
315106
315106
max_disdance(v
1
)=12
,<
br>max_disdance(v
2
)=15
,设乡镇
v
i到其他各乡镇的最远距离为
max_disdance(v
i
)
,则有:
max_disdance(v
3
)=10
,
max_disdan
ce(v4)=10
,
max_disdance(v
5
)=15
,
所以可知消防站应建在
v
3
或
v
4
乡镇,才
能使离
消防站最远的乡镇到消防站的路程最短。
五、(本题8分)
【解答】对
n
用归纳法证明。当
n
=
1
时,有
N1=F3-l=2-l=
1
到。当
n=2
时,有
N2=F4-1=3-1=2
。设
n
N
n
=F
n+2
-1
成立。<
br>
当
n=k+1
,对于一个
k+l
层深度的平衡二叉树而言,
其左右子树都是平衡的。结点数为最少的极端情况,
故左右子树中的结点数是不相等的,设其中一个是<
br>k
层深度的二叉平衡树,另一个是
k-l
层深度的二叉平衡树。
所以有
:
N
k+1
=1+N
k
+N
k-1
==
1+(F
k+2
-1)+(F
k+1
-1)=
F
k+2
+F
k+1
-1= F
k+3
-1
当
n=k+1
时成立,由此可知深度为
n
都等式都成立。
六、(本题8分)
【解答】
n
个结点的平衡二叉树的最大高度为
h
log(5(n1))2
,设表示高度需
xbit
,则有关系
15<
br>2
式:
2
x
≥
h
>
2
x-1
,所以有:
x
log
2
h
log
2
(log
15
(5(n
1))2)
2
15
h2
()
2(
2
)设深度为
h
的平衡二叉树的最少关键字数为
n
h
,则有公式:
n1
,本题中
8bit
的计数
h
5
15
258
()
8
2
器共可以表示
2=256
层,即高度为
256
,从而可知最少有
n1
个关键字。
5
七、(本题8分)
【解答】
(
1
)线性探测再散列的哈希表查找成功的平均查找长度
为:
S
nl
也就是
12m
≤
4
/
5
,
所以
m
≥
15
,可取
m=15
。
(
2
)散列函数可取为
H(key)=key % 13
(
3
)散列表如表
7-4
所示。
散列表
0
1
40
2
66
3
94
4
5
5
6
58
7
33
8
47
9
72
10
87
11
22
12
25
13
12
14
11
(1)
≤
3
,解得α≤
4
/
5
,
21
(
4
)
12
个数据
{25,
40
,
33
,
47
,
12
,
66
,
72
,
87
,
94
,
22
,
5
,
58
}的比较次数分别是:
1
,
1
,
1
,
1
,
2
,
2
,
3
,
2
,
1
,
3
,
1
,
1
。
可知查找成功的平均查找次数
=(1+1+1+1+2+2+3+2+1+3+
1+1)12=1.25
八、(本题8分)
【解答】有
n
个叶子结点的带
权路径长度最短的二叉树称哈夫曼树,同理,存在有
n
个叶子结点的带权
路径长度最短
的三叉、四叉、
……
、
k
叉树,也称为哈夫曼树。如叶子结点数目不足以构成
正则的
k
叉树(树
中只有度为
k
或
0
的结点),即
不满足
(n-l)MOD(k-l)=0
,需要添加权为
0
的结点,添加权为
0
的结点的个数
为:
k-(n-1)MOD(k-1)-1
。添加的
位置应该是距离根结点的最远处。
所构造出的哈夫曼树如下图所示:
<
br>其中,每个字母的编码长度等于叶子结点的路径长度,电文的总长度为
wl
=
191
。
ii
i1
n
m=n
k
+n<
br>,注释:对于正则的
k
叉树,设叶结点数为
n
,度为
k
的结点数为
n
k
,结点总数为
m,
则有
m-1=knk
,
两式相减可得
n-1=(k-1)n
k
,即
(n-
l)MOD(k-l)=0
;如
n
与
k
不满足此关系,
n<
br>加上
k-(n-1)MOD(k-1)-1
后,
n’=
n+(k-(n-1)MOD(k-1)-1)
,这时:
(n’-l)MO
D(k-l)=(n+(k-(n-1)MOD(k-1)-1)-l)MOD(k-l)
=((n-1)+(k-1)-(n-1)MOD(k-1))MOD(k-l)
=((n-1)-(n-1)MOD(k-1))MOD(k-l)
=0
。
现有
12
个初始归并段,其记录数分别为{
30,44,8,6,3,20,
60,18,9,62,68,85
},采用
3-
路平衡归并,画出最
佳归并
树。
九、(本题9分)
【解答】设该树中结点总数为
N
,叶子结点个数为
N
0
,则有:
N
N
i0
m
i
i
(
1
)
(
2
)
N1
iN
i1
m
由(
2
)
-
(
1
)再经过移项可得:
N
1
m
(i1)N
0i
i1
十、(本题15分)
【解答】
对
于排列的解空间可构造一个虚拟的解空间树,比如
n=5
,
k=3
时的解空间
树如下图所示,可采用对此
树进行先序遍历方式进行遍历,并用递归法进行递归输出从
n
个数中挑选
k
个进行排列所得序列。
具体算法实现如下:
文件路径名
:exam7alg.h
template
void Arrage(ElemType a[],int k,int
n, int outlen=0)
操作结果
:
回溯法输出排列序列,
a[0..k-1]
为
k
个数的排列序列
outlen
为当
前所求排列
序列的长度,其中
outlen=k
时的排列序列为
所求;
n
为
list
数组长度
{
if (k
< 0 || k >= n) return;
此时无排列
int
i;
临时变量
if (outlen == k + 1)
{
得到一个排列
for (i = 0; i < k;
i++)
{
输出一个排列
cout << a[i];
输出
a[i]
}
cout <<
用空格分隔不同排列
}
else
{
对解空
间进行前序遍历,
a[outlen..n]
有多个排列,递归的生成排列
for (i = outlen; i < n; i++)
{
处理
a[i]
Swap(a[outlen+1], a[i]);
交换
a[outlen+1]
与
a[i]
Arrage(a, k, n, outlen + 1);
对序列长度
outlen+1
递归
Swap(a[outlen+1], a[i]);
交换
a[outlen+1]
与
a[i]
}
}
}
*模拟试题(八)
注:本套试题选作
一、单项选择题(每小题
2 分,共20分)
(
1
)一个
n*n
的带状矩阵
A=[a
ij
]
如下:
a
11
a
21
A
a
12
a
22a
32
a
23
a
33
a
34
a
n2,n1
a
n2,n2
a
n
1,n
a
n2,n1
a
n1,n1
a
n,n1<
br>
a<
br>n1,n
a
nn
将带状区域中的元素
a
ij
(
|i-j|
≤
1
)按行序为主序存储在一维数组
B[3n-2]
中,元素
a
ij
在
B
中的存储位置
是
( )。
A
)
i+2j-2
B
)
2i+j-3 C
)
3i-j
D
)
i+j+1
(
2
)一
n
×
n
的三角矩阵
A=[a
ij
]
如下:
a
11
a
12
a
22
a
1n
a
2n
a
nn
将三角矩阵中元素
a
ij
(i
≤
j)
按行序为主序的顺序存储在一维数组
B[n
(n+1)2]
中,则
a
ij
在
B
中的位置是
(
)。
A
)
(i-1)(2n+i)2+i-j
B
)
(i-1)(2n-i+2)2+j-i
C
)
(i-1)(2n-i)2+j-i-1
D
)
(i-1)(2n-i+2)2+j-i-1
(
3
)设有一
棵度为
3
的树,其叶结点数为
n
0
,度为
1
的结点
数为
n
1
,度为
2
的结点数为
n
2
,度为
3
的
结点数为
n
3
,则
n
0
与<
br>n
1
,
n
2
,
n
3
满足关系(
)。
A
)
n
0
=n
2
+1
B
)
n
0
=n
1
+2n
3
+1
C
)
n
0
=n
2
+n
3
+1 D
)
n
0
=n
1
+n
2
+n
3
<
br>(
4
)
G
是一个非连通无向图,共有
28
条边,则该
图至少有( )个顶点。
A
)
6 B
)
7
C
)
8 D
)
9
(
5
)设图
G
用邻结表存储,则拓扑排序的时间复杂度为(
)。
A
)
O(n) B
)
O(n+e)
C
)
O(n
2
) D
)
O(n×e)
(
6
)用
n
个键值构造一棵二叉排序树,最低高度为(
)。
n
B
)
n
C
)
nlog
2
n
D
)
log
2
n
1
2<
br>(
7
)若需在
O(nlogn)
的时间内完成对数组的排序,且要求排
序是稳定的,则可选择的排序方法是
A
)
k i k i k i k i k i k i
( )。
A
)快速排序
B
)堆排序
C
)归并排序
D
)直接插入排序
(
8
)在文件“局部有序”或文件长度较小的情况下,最佳内部排序的方法是(
)。(北方名校经
典试题)
A
)直接插入排序
B
)起泡排序
C
)简单选择排序
D
)基数排序
(
9
)一棵有
124
个叶结点的完全二叉树,最多有(
)个结点。
A
)
247 B
)
248
C
)
249 D
)
250
(
10
)一个序列
中有10000个元素,若只想得到其中前10个最小元素,最好采用 ( )方
法。
A)快速排序 B)堆排序
C)插入排序 D)二路归并排序
二、(本题8分)
要借助栈由输入序列是输入
1,2,3,
…
,n
得到的输出序列为
p
1
,p
2
,p
3
,<
br>…
,p
n
(
此输出序列是输入序列经过栈操作
后的某个排列<
br>)
,则在输出序列中不可能出现当
i
p
j
的情况。
三、(本题8分)
已
知某一完全
k
叉树只有度为
k
的结点及叶结点,设叶结点数为
n0
,试求它的树高
h
。(南方名校经典
试题)
四、(本题8分)
试讨论怎样在一棵中序线索二叉树上查找给定结点
x
在后序序列中的后继。
五、(本题8分)
具有
n
个关键字的
B
一树的查找的最大路径长度是多少?
六、(本题8分)
对长度为
12
的有序表
(a
1
,
a
2
,…,
a
12
)
(其中
a
i
j
当
i
x1
、
x>a
12
以及
a
i
(i=1,2,…,11)
等情况发生的概率相等,则查找不
成功的平均查找长度是多少?
八、(本题8分)
(
1
)设
T
是具有
n
个内结点的判断二叉树,
I
是它的内路径长度,
E
是它的外路径长度,试利用归纳法
证明
E
=
I
+2n
,
n
>
0
。
(
2
)利
用(
1
)的结果,试说明,成功查找的平均比较次数
s
与不成功查找的平均比
较次数
u
之间的关
系,可用公式
s(1
1
n
)
u1
,
n
>
0
表示。
提示:判断二叉树只有度
为
0
或度为
2
的结点;判断二叉树成功查找的比较次数为内路径长度与内结点
数之和,不成功查找的比较次数为外路径长度。
九、(本题9分)
一个深
度为
h
的满
m
叉树有如下性质:第
h
层上的结点都是叶结点
,其余各层上每个结点有
m
棵非空子
树。问:
(
1
)第
k
层有多少个结点?(
k
≤
h
)
(
2
)整棵树有多少个结点?
(
3
)若按层次从
上到下,每层从左到右的顺序从
1
开始对全部结点编号,编号为
i
的结点的双
亲结点的编号
是什么?编号为
i
的结点的第
j
个孩子结点(若存在)
的编号是什么?
十、(本题15分)
设散列表的关键字取值范围为
0 ~
m-1
,
n
为对散列表的最大插入次数,设计散列表,允许使用以
O(m+n
)
空间,要求查找、插入和删除算法的时间复杂度都是
O(1)
。
模拟试题(八)参考答案
一、单项选择题(每小题 2 分,共20分)
(
1
)参考答案:
B
)
(
2
)
【分析】存储位置
=n+(n-1)+…+(n-i+2)+i-j=(i-1)(2n-i+2)2+
j-i
。
参考答案:
B
)
(
3
)【分析】用
n
表示结点总数,则有:
n=
n
0
+n
1
+n
2
+n
3
;
由于除根结点而外,结点与分支一一对应,而分支数
=
n
1
+2n
2
+3n
3
,即有:
n-1=
n
1
+2n
2
+3n
3
。
由上面两式可
得:
n
0
=n
1
+2n
3
+1
参考答案:
B
)
(
4
)【分析】本题中由于是非
连图,至少有一个顶点与其他顶点不连,这个顶点是孤立点,其他顶点可
组成一个连通图,由于
8
个顶点的完全图共有
28
条边,所以具体
28
个顶点的连通图的顶
点个数至少为
8
,这
样非连通图至少有
9
个顶点。
参考答案:
D
)
(
5
)【分析】对于有
n
个顶点
e
条边的有向图,建立各顶点的入度时间复杂度为
O(e)
,建立入度为零的
栈的时间复杂度为
O(n)
,在拓扑排序过程中,最多每个顶点进一
次栈,入度减
1
的操作最多总共执行
e
次,
可知总的时间复杂度为<
br>O(n+e)
参考答案:
B
)
(
6<
br>)【分析】当用
n
个键值构造一棵二叉排序树是一棵完全二叉树时,高度最低,此时高度
为
log
2
n
1
。
参考答案:D
)
(
7
)【分析】快速排序和堆排序都是不稳定的,应排除
;归并排序稳定,时间复杂度
O(nlogn)
,满足条
件;直接插入排序,时间复杂
度为
O(n
2
)
,排除。
参考答案:
C
)
(
8
)【分析】对直接插入排序
而言,算法时间复杂度为
O(n
2
)
,但若待排记录序列为“正序”时,其时
间复杂度可提高至
O(n)
。若待排记录序列按关键字“基本有序”,直接插入排序的
效率就可大大提高,此外
由于直接插入排序算法简单,在
n
值很小时效率也高。
参考答案:
A
)
(
9
)【分析】完全二
叉树中度为
1
的结点最多只有
1
个,由二叉树的度和结点的关系:
n=n
0
+n
1
+n
2
(1)
n=n
1
+2n
2
+1
(2)
<
br>由
2(1)-(2)
得,
n=2n
0
+n
1
-1=247+n
1
≤
248
,所以本题应选择
B
)。
参考答案:
A
)
(
10
)参考答案:
B
)
二、(本题8分) <
br>【解答】设
p
j
成立,则表示
在
p
i
出栈之前
p
j
和
p
k
都已
入栈,并且还留在栈中,但要满足
p
j
的出
栈次序是
不可能的,由于按照
i
p
j
和
p
k
同时在栈中时,必然
p
k
被
p
j
盖住,由栈的
后进先出的
性质,当
i
p
k
<
p
j
,与假设矛盾。
三、(本题8分)
【解答】设度为
k
的结点数为
n
k
,结点总数为
n
,则有如下关系:
n= n
k
+n
0
又由于树中只有
n-1
条边,所以:
n-1=k
×
n
k
由①与②可得:
n
k
=(n
0
-1)
(k-1)
,进而有
n=
①
②
kn
0
1
k1
(k-1)
≤
k
h
-1
对于
k<
br>叉完全树有如下关系:
k
h-1
-1
<
n×
(k-1
)
<
k
h
,从而:
h-1
≤
log
k(n×(k-1))
<
h
,进而:
h
log
k
(n(k1))
1
即有:
k
h-1
≤
n×
所以:
h=
log
k
(kn<
br>0
1)
1
四、(本题8分)
【解答】由于
后序遍历二叉树需要知道的关键是访问当前结点的双亲结点,需要由中序线索树才能得到
当前结点的双亲
,中序线索树有如下性质:
若
x
是
parent
的左孩子
,则
parent
是
x
的最右子孙的右线索;
若
x
是
parent
的右孩子,则
parent
是
x
的最左子孙的左线索。
用以上性质能找到
x
的双亲结点
parent
。
若
x
是
parent
的右孩子,则
parent
结点就是<
br>x
的后序序列的后继结点;如下图(
1
)中结点①的后继是结
点②。<
br>
若
x
是
parent
的左孩子,则:
如
果
parent
的右指针域为线索的话,那么
parent
就是
x<
br>的后序序列的后继结点,如下图(
2
)中结点②的
后继是结点③。
否则
parent
右子树中最左边第一个左右孩子均为线索的结点,就是
x
的后序序列的后继结点。如下图(
3
)
中结点②的后继是结点③。
五、(本题8分)
【解答】树的查找路径是从根结点开始到所要查找的结点的路径
,最大不会超过
B-
树的深度。在
B
树中,
除根结点外所有非终端结
点都含有
m
棵子树,所以有
n
个关键字的<
br>B-
树的最大深度为根结点具有两棵子
2
树,
其余非终端点有
m
棵子树,设最大路径长度是
x,由于叶子结点表示查找不成功,叶子结点不含关键
2
字,可知<
br>B-
树的深度为
x+1
,
第
1
层共有
1
个结点,含
1
个关键字;
第
2
层共有
2
个结点,含
2(
m
-1)
个关键字;
2
第
3
层共有
2
……
m
m
m
2(-1)
个关键字;
个结点,含
222
x2
m
第
x
层共有
2
2
m
个结点,含
2
2
x2
(
m
-1)
个关键字;
2
m
m
(-1)
=
2
2
2
x1
故,共含有的关键个数为:
m<
br>
m
m
m
1+2(-
1)+2(-1)+
…
+2
2
2
2
2
x2
1
m
由此可得:
n2
2
x1
1
,解得:<
br>x1log
m
(
2
n1
)
,这就是具有
n
个关键宇的
B
一树的查
2
找的最大路径长度。
六、(本题8分)
【解答】折半查找对应
的判定树如下图所示。查找不成功的对应于外部结点。查找不成功所走的路径是
从根结点到每个外部结点
(图中方块结点),和给定值进行比较的关键字个数等于该路径上内部结点个数。
在不成功情况下,一共比较的次数为
3*3+4*10=49
次。
平均查找长度为
4913
≈
3.77
七、(本题8分)
【解答】对于
a
来说,在
S2
中总可找到离
a
最近的祖先结
点
d
,这时
a
d
为
b
的右孩
子,则
有
a
在
b
的右子树上,所以
a>b
,也就是
说
a并不总是成立,同理
b
八、(本题8分)
【解答】
(
1
)证明:
n=1
时显然成立,设
n=k
时成立,即
E
k
=I
k
+
2k
,当
n=k+1
时,设所增加的结点的路径长度
为
D<
br>k
,则有:
I
k+1
=I
k
+D
k
E
k+
1
=E
k
-D
k
+2(D
k
+1)=E
k
+D
k
+2=I
k
+2k+D
k
+2=I
k+1
+2(k+1)=I
k+1
+2n
结论也成立。
(
2
)根据二叉树性质:度为
0
的结点数
=
度为
2
的结点数
+1
,所以外结点数
=n
+
l
。
s=
查找成功总的比较次数
内结点数
=(I+n)n
①
u=
查找失败总的比较次数
外结点数
=E(n
+1)=(I+2n)(n+1)
②
由①得:
I=ns-n
,由②得:
I=(n+1)u-2n
,所以可得:
ns-n=(n+1)u-2n,进一步得:
s(1
1
n
)u1
。
九、(本题9分)
【解答】
(
1
)设第<
br>v
层有
u
个结点
(m
v
层
的每个结点有
m
个孩子,所以第
v+1
层的结点个数为
mu
。
第
1
层有
1
个结点,第
2
层有
m
个结点,第
3
层有
m
2
结点,用数学归纳法易知
k
层共有
m
k-1
个结点。
m
h
1
(
2
)整棵树结点数
=1+m+m+
…
+m=
。<
br>
m1
2h-1
(
3
)设编号为
i
的结点
双亲的结点编号为
x
,将编号为
i
的结点视为完全二叉树的最后一个结点,因
此,
此完全
m
叉树中至少有
x-l
个度为
m
的结点,而
x
号结点的度
d
(
1
≤
d
≤
m
),其余的结点均为叶子结点,
而编号
i
就是此完全
m
又树的总结局数,于是有:
(x-1)m+d+1=i
所以有
x
imd1
,由于
1
≤
d
≤
m<
br>,所以有:
m
im2imim2
11
x
mmm
可知:
x
im2
。
m
设编号为
i
的第
j
个
子结点为完全
m
叉树的最后一个结点
n
,此完全
m
叉树中有
i-1
个度为
m
的结点,
m+j+1
一个度为
j
的结点,其他结点均为叶子结点,可得:
n=(i-l)×
十、(本题15分) 【解答】在理想情况下,可实现散列表查找、插入、删除操作的操作时间为
O(1)
,对于
本题,由于已经知道了
关键字的取值范和散列表的最大插入次数,可作理想化处理哈希方法:将查找与数
据在一起的哈希表一分为二:采
用两个数组
ht
和
elem
,其中
ht
是从
0
到
m-1
的整数数组
(做索引用);
elem
数组的数据类型为哈希表中各元素的
类型,其元素个数为n
(即最大的插入次数),两个数组都不需要初始化。使用计数器
lastE
表示
上次所用到的
elem
中的位置,初值为
-1
。
ht[k]
中的值可能无效(用
-1
表示)也可能是
elem
的索引(用来寻找关键字为
k
的元素),如
下图所示:
具体算法实现当如下:
文件路径名
:exam8alg.h
理想散列表类
template
class IdealHashTable
{
protected:
散列表的的数据成员
:
int *ht;
用作
elem
的索引
ElemType *elem;
在放插入的哈希表的元素
int
lastE;
计数器,表示上次用到的
elem
位置
int n;
最大插入次数
int m;
关键字范围
0~m-1
public:
理想散列表方法声明及重载编译系统默认方法声明
:
IdealHashTable(int maxInsertCount, int size);
构造函数
~IdealHashTable();
析造函数
void Traverse(void
(*Visit)(const ElemType &)) const;
遍历散列表
bool Search(const KeyType &key, ElemType &e)
const;
查寻关键字为
key
的元素
bool
Insert(const ElemType &e);
插入元素
e
bool Delete(const KeyType &key, ElemType &e);
删除关键字为
key
的元素,用
e
返回元素值
IdealHashTable(const IdealHashTable
复制构造函数
IdealHashTable
(const IdealHashTable
赋值语句重载
};
理想散列表类的实现部分
template
IdealHashTable
操作结果
:
构造最大插入次数为
maxInsertCount,
关键字范围为
0~size-1
的空理想散列表
{
n
= maxInsertCount;
最大插入次数
m = size;
关键字范围为
0~size-1
ht = new int[n];
为
elem
索引表分配存储空间
elem = new
ElemType[m];
为元素分配存储空间
lastE = -1;
初始化
lastE
for (int pos = 0; pos < n;
pos++)
{
初始化
ht
ht[pos] = -1;
}
}
template
IdealHashTable
操作结果
:
销毁散列表
{
delete []ht;
释放
ht
delete []elem;
释放
elem
}
template
void
IdealHashTable
操作结果
:
依次对散列表的每个元素调用函数
(*visit)
{
for (int pos = 0; pos < m; pos++)
{
对散列表的每个元素调用函数
(*visit)
if (ht[pos] != -1) (*Visit)(elem[ht[pos]]);
}
}
template
bool IdealHashTable
初始条件
:
关键字
key
的范围为
0~m-1
,
ht[key]
的范围为
0~lastE
操作结果
:
查寻关键字为
key
的元素的值
,
如
果查找成功
,
返回
true,
并用
e
返回元素的值
,
否则返回
false
{
if (key < 0
|| key >= m)
{
范围错
return
false;
查找失败
}
else if
(ht[key] < 0 || ht[key] > lastE || elem[ht[key]]
!= key)
{
表中没有要查找的元素
return
false;
查找失败
}
else
{
存在要查找的元素
e = elem[ht[key]];
用
e
返回元素值
return true;
查找成功
}
}
template
bool
IdealHashTable
操作结果
:
将元素插入到
elem
数组
lastE
位置,同时修改索引值
{
KeyType key = e; e
的关键字
ElemType
eTmp;
临时变量
if (key < 0 || key >=
m)
{
范围错
return false;
插入失败
}
else if (Search(key,
eTmp))
{
查找成功
return false;
插入失败
}
else if (lastE == n - 1)
{
超过最大插入次数
return false;
插入失败
}
else
{
elem[++lastE] = e;
修改计数器,将元素插入到表中
ht[key] = lastE;
索引表
ht
中
ht[key]记录关键字为
key
的元素在
elem
中的位置
return true;
插入成功
}
}
template
bool IdealHashTable
操作结果
:
删除关键字为
key
的数据元素
,
删除成功返回
true,
并用
e
返回元素值,否则返回
fa
lse,
通过将
lastE
位置元素移到删除位置,
lastE
指向倒数第二个元素,从逻辑上完成删除
{
if
(!Search(key, e))
{
查找失败
return false;
删除失败
}
else
{
查找成功
e = elem[ht[key]];
用
e
返回被删除元素值
elem[ht[key]] =
elem[lastE--];
将最后元素移到所删除处
,
将修改
Las
tE
指向新的末记录
int k = elem[ht[key]];
原最后元素的关键字
ht[k] = ht[key];
修改索引值
ht[key] = -1;
修改
ht
[key]
为
-1
,表示关键字为
key
的元素已初删除
return true;
删除成功
}
}
template
IdealHashTable
const
IdealHashTable
操作结果:由散列表
copy
构造新散列表
--
复制构造函数
{
n = copy.n;
最大插入次数
m
= copy.m;
关键字范围为
0~m-1
ht = new
int[n];
为
elem
索引表分配存储空间
elem = new ElemType[m];
为元素分配存储空间
lastE =
计数器,表示上次用到的
elem
位置
int pos;
临时变量
for
(pos = 0; pos < m; pos++)
{
复制元素索引
ht[pos] = [pos];
复制元素索引值
}
for (pos = 0; pos < m; pos++)
{
依次复制数据元素
elem[pos] = [pos];
复制元素值
}
}
template
IdealHashTable
operator=(const IdealHashTable
操作结果:将散列表
copy
赋值给当
前散列表
--
赋值语句重载
{
if (© !=
this)
}
{
delete []ht;
delete []elem;
释放
ht
释放
elem
最大插入次数
关键字范围为
0~m-1
为
elem
索引表分配存储空间
为元素分配存储空间
计数器,表示上次用到的
elem
位置
n = copy.n;
m = copy.m;
ht = new int[n];
elem = new ElemType[m];
lastE =
int pos;
临时变量
for (pos = 0; pos
< m; pos++)
{
复制元素索引
ht[pos] =
[pos];
复制元素索引值
}
for (pos = 0;
pos < m; pos++)
{
依次复制数据元素
elem[pos] = [pos];
复制元素值
}
}
return *this;
(1)若以1234作为双端队列的
输入序列,则既不能由输入受限双端队列得到,也不能由输出受限双端队列
得到的输出序列是(
)。
A
)
1234 B
)
4132
C
)
4231 D
)
4213
(
2
)将一个
A[1..100,1..100]
的三对角矩阵,按行优先存入一维数组
B[298
]
中,
A
中元素
a
66,65
在
B
数组<
br> B
)
195
C
)
197
中的位置
k
为(
)(假设
B[0]
的位置是
1
)。
A
)
198
D
)
198
(
3
)若度为
m
的哈
夫曼树中,其叶结点个数为
n
,则非叶结点的个数为( )。
A
)
n-1 B
)
n
1
m
C
)
n1
m1
D
)
n
1
m1
(
4
)若一个有向图具有拓扑排序序列,并且顶点按拓扑排序序列编号,那么它的邻接矩阵必定为
(
)。
A
)对称矩阵
B
)稀疏矩阵
C
)三角矩阵
D
)一般矩阵
(
5
)设森林
F
对应的二叉树为有
m
个结点,
此二叉树根的左子树的结点个数为
k
,则另一棵子树的结
点个数为(
)。
A
)
m-k+1 B
)
k+1
C
)
m-k-1 D
)
m-k
(
6
)假定有<
br>K
个关键字互为同义词,若用线性探测法把这
K
个关键字存入散列表中,至少要
进行( )
次探测。
A
)
K-1
次
B
)
K
次
C
)
K
+
l
次
D
)
K(K+1)2
次
(
7
)一棵
深度为
k
的平衡二叉树,其每个非终端结点的平衡因子均为
0
,则该树共有(
)个结点。
A
)
2
k-1
-1
B
)
2
k-1
C
)
2
k-1
+1
D
)
2
k
-1
(
8
)如表
r
有
100000
个元素,前
99999
个元素递增有序,则采用(
)方法比较次数较少。
A
)直接插入排序
B
)快速排序
C
)归并排序
D
)选择排序
(
9
)如果只考虑有序树的情形,那么具有
7
个结点的不同形态的树共有(
)棵。
A)132 B)154 C)429 D)前面均不正确
(
10
)对
n(n>=2)
个权值均不相同的字符构成哈夫曼树,关于该树的叙
述中,错误的是(
)。
A
)该树一定是一棵完全二叉树
B
)树中一定没有度为
1
的结点
C
)树中两个权值最小的结点一定是兄弟结点
D
)树中任一非叶结点的权值一定不小于下一任一结点的权值
二、(本题8分)
斐波那契数列
Fn
定义如下:
F0
=0
,
F
1
=1
,
F
n
=
F
n-1
+F
n-2
请就此斐波那契数列,回答下列问题:
(
1
)在递归计算
F
n
的时候,需要对较小的
F
n-1
,
F
n-2<
br>,…,
F
1
,
F
0
精确计算多少次?
(
2
)若用有关大
O
表示法,试给出递归计算
Fn
时递
归函数的时间复杂度是多少?
三、(本题8分)
证明:如果一棵二叉树的后序序列
是
u
1
,
u
2
,
…
,
u
n
,中序序列是
u
p
,
u
p
,
…
,
u
p
,则由序列
1,2,
…
,n
可通
1
2n
过一个栈得到序列
p
1
,
p
2
,
…<
br>,
p
n
。
四、(本题8分)
如下图所示为
5
个乡镇之间的交通图,乡镇之间道路的长度如图中边上所注。现在要在这
5
个乡镇
中选
择一个乡镇建立一个消防站,问这个消防站应建在哪个乡镇,才能使离消防站最远的乡镇到消防站的
路程最
短。试回答解决上述问题应采用什么算法,并写出应用该算法解答上述问题的每一步计算结果。
1
3
5
6
4
9
4
12
2
6
3
五、(本题8分)
证明一个深度为
n
的
A
VL
树中的最少结点数为:
Nn=F
n+2
-1
(n
≥
0)
其中,
Fi
为
Fibonacci
数
列的第
i
项。
六、(本题8分)
简单回答有关
AVL
树的问题:(北方名校经典试题)
(
1
)在有
n
个结点的
AVL
树中,为结点增加
一个存放结点高度的数据成员,那么每一个结点需要增加
多少个字位(
bit
)?
(
2
)若每一个结点中的高度计数器有
8bit
,那么这样的
AVL
树可以有多少层?最少有多少个关键字?
七、(本题8分)
设有
12
个数据
{25
,
40
,
33<
br>,
47
,
12
,
66
,
72
,87
,
94
,
22
,
5
,
58},它们存储在散列表中,利用线性探测再
散列解决冲突,要求插入新数据的平均查找次数不超过3
次。
(
1
)该散列表的大小
m
应设计多大?
(
2
)试为该散列表设计相应的散列函数。
(
3
)顺次将各个数据散列到表中。
(
4
)计算查找成功的平均查找次数。
八、(本题8分)
已知某电文中共出现了
10
种不同的字母,每个字母出现的频率分别为
A
:
8
,
B
:
5
,
C
:
3
,
D
:
2
,
E
:
7
,
F
:
23
,
G
:
9
,
H
:
11
,
I
:
2
,
J
:
35
,现在对这段电文
用三进制进行编码(即码字由
0
,
l
,
2
组成),问
电文编码总长度至少有多少位?请画出相应的图。
九、(本题9分)
已知一棵
度为
m
的树中有
N
1
个度为
1
的结点,
N
2
个度为
2
的结点,…,
N
m
个度为
m<
br>的结点。试问该
树中有多少个叶子结点?(北方名校经典试题)
十、(本题15分)
试用递归法编写输出从
n
个数中挑选
k
个进行排列所得序列的算法。
模拟试题(七)参考答案
一、单项选择题(每小题 2 分,共20分)
(
1
)参考答案:
C
)
(
2
)
【分析】如下所示,三对角矩阵第
1
行和最后
1
行非零元素个数为
2
个,其余各行的非零元素个数是
3
个,所知
a
66,65
前
面共有
2+3*64
=
194
个非零元素,
a
66,65<
br>本身是第
195
个非零元。
a
11
a
21
A
a23
a
33
a
34
a
n2,n
1
a
n2,n2
a
n1,n
a
n2,
n1
a
n1,n1
a
n,n1
a
n1,n
a
nn
a
12
a
22
a
3
2
参考答案:
B
)
(
3
)【分析】在哈夫曼树的
非叶结点中最多只有
1
个结点的度不为
m
,设非叶结点的个数为
k<
br>,则其中
有
k-1
个结点的度为
m
,设另
1
个结点的度为
u
,则
2
≤
u
≤
m
,设结点
总数为
n
总
,则有如下关系:
n
总
-1=m(k-1)+u
①
n
总
=k+n
②
将②代入①可得:
k+n-1= m(k-1)+u
,解得:
k
(
n1)(mu)
,由于
2
≤
u
≤
m
,所以可
得
0
≤
m-u
m1
<
m-1
,所以可得:
n1n1
n1
+1
,可知
k
≤k
<。
m1m1
m1
参考答
案:
C
)
(
4
)【分析】设顶点按拓扑排序序列为:v
0
,v
1
,…,v
n-1
,则对于邻接矩阵
A
,只有当
i
<
v
i
,v<
br>j
>
,也就是当
i>j
时,一定没有弧
< v
i,v
j
>
,所以这时
A[i][j]=0
,可知邻接矩阵为三角
矩阵。
参考答案:
C
)
(
5
)【分析】设另一棵子树的结点个数为
n
,所以有
m=n+k+1
,可知
n= m-k-l
。
参考答案:
C
)
(
6
)【分析】因为
K
个关键字互为同义词,只有在存入第一个关键字的情况下不发生冲突,所以至少
需进行
1+2+
…
+K=K(K+1)2
次探测。
参考答案:
D
)
(
7
)【分析】由于每个非终端
结点的平衡因子均为
0
,所以每个非终端结点必有左右两个孩子,且左子
树的高度和右
子树的高度相同,这样
AVL
树是满二叉树。高度为
k
的满二叉树的结点数为
2
k
-l
。
参考答案:
D
)
(
8
)【分析】本题中只有直接插入排序利用前面有序的子序列这个性质,如用直接插
入排序对本题只需将最
后一个元素插入到前面
99999
个元素的有序子序列中即可,
显然比较次数较少。
参考答案:
A
)
(
9)【分析】具有
n
个结点有不同形态的树的数目和具有
n-l
个结点互不
相似的二叉树的数目相同(将
树转化为二叉树时,根结点右子树为空,所以除根结点而外只有左子树,其
不相似的二叉树的等价于不相似
的左子树)。具有
n
个结点互不相似的二又树的数目为
参考答案:
A
)
(
10
)参考答案:
A
)
二、(本题8分)
【解答】
1
1
n
6
C
2
C12
132
。
n
,本题中应为
n1
61
(
1
)设在计算
F
n
时,由
F
n-1+F
n-2
可知
F
n-1
要精确计算
1
次;<
br>
由
F
n-1
=F
n-2
+F
n-3
可知
F
n
=2F
n-2
+F
n-3
,
F
n-2
要精确计算
2
次;
由
F
n-2<
br>=F
n-3
+F
n-4
可知
F
n
=3Fn-3
+2F
n-4
,
F
n-3
要精确计算
3
次,
F
n
=3F
n-3
+2F
n-4
公式
中
F
n-3
的系数为
F
n-3
要精确
F
n
=a
j
*F
n-j
+a
j-1
*F
n-j
-1
。
计算次数,而
F
n-4
的系数为
F
n-2
要精确计算次数,以此类推,设
F
n-j
的精确计算次为
a
j
,则有:
由
F
n-j
=F
n-j-1
+
F
n-j-2
可知
F
n
=(a
j
+ a
j
-1
)*F
n-j-1
+a
j
*F
n-j-2
<
br>,
F
n-j-1
的精确计算次数为
a
j+1
,所以有
:
a
j+1
=a
j
+a
j-1
F
n-2
,
F
1
,
F
0
的精确计算次为
:
1
,
2
,
3
,
5
,由于
Fn-1
要精确计算
a
1
为
1
次,即
a
1
=1
,即可知
F
n-1
,…,……,
a
j
=a
j-1
+a
j-2
……
与斐波那契数列数列:
0
,
1
,
2
,<
br>3
,
5
,……,
F
n
=F
n-1
+
F
n-2
……
比较可知
a
j
=F
j+1
。
(
2
)由于
F
n
的计算最终要转化为
F
0
与
F
1
之和,其加法的计算次数为
F
0
与
F
1
的精确计算次数之和再减
1
之差,由于
F
0
=F
n-n<
br>与
F
1
=F
n-(n-1)
,所以计算
F
n
时,加法计算次数为:
a
n
+a
n-1
-1=F
n+1
+F
n
-1
由于
Fn=
115
n
115
n
15
n
()()
,可知时间复杂度为<
br>O(
()
)
。
22
2
55
三、(本题8分)
【解答】当
n=1
时,结论显然成立。
设
n<=k
时结论成立,当
n=k+1
时,设一棵二叉树的后序序列是
u
1
,
u
2
,
…
,
u
n
,中序序列是
u
p
,
u
p
,
…
,
u
p
,
12n
{
u
p
,
u
p
,
…
,
u
p
}
可知
u
n
是二叉树的根结点,设p
j
n
,可知
{
u
p
,
u
p
,
…
,
u
p
}
是左子树的结点集合,
1
2n
j1j1j2
是右子树的结点集合,进一步可知:
(
1
)左子树的后序序列是
u
1
,
u
2
,
…<
br>,
u
j1
,中序序列是
u
p
,
u
p
,
…
,
u
p
,由归纳假设知序列
1,2,
…
,j-1
12
j1
可以通过一个栈得序列
p
1
,
p
2
,
…
,
p
j1
。
<
br>(
2
)右子树的后序序列是
u
j
,
u
j1
,
…
,
u
n1
,中序序列是
u
p,
u
p
,
…
,
u
p
,设
u
1
…,
u
j
,
u
j1
,
u
2
n
j1j2
j
u
n1
;
u
p
1
p
j1
j1
,
p
2
p
j2
j1
,…,
u
n
u
p
j2
,…,
u
p
nj
u
p
n
,则
p
1
u
p
j1
,
u
p
2
,
p
2
,…,
p
n
j
p
n
j1
,由归纳假设知序列
1,2,
…,n-j
可以通过一个栈得序列
p
1
j
,显然按同
样的
p
n
方式,
j,j+1,
…
,n-1 可以通过一个栈得序列
j1p
1
,
j1p
2
,
…
,
j1p
n
j
,
也就是
p
j1
,
p
j2
,…,
p
n<
br>。
由(
1
)(
2
)及
p
j
n可知由
1,2,
…
,n
可通过一个栈得到序列
p
1,
p
2
,
…
,
p
n
。由数学归纳法可
知本题结
论成立。
四、(本题8分)
012
120
96
3
9
6
0
4
4
0
6
4
0
6
【解答】由弗洛伊德(
Floyd
)算法进行求解,具体步骤如下:
3
0129
120
6
,
(0)
D
960
6
4
0
31512
4
0
6
3
15
;
12
6<
br>
0
D
(1)
D
(1)
<
br>0129
1206
960
4
31512
3
0129133
120
15
,
61015
;
(2)
12
D
960412
6
13104
06
0
0
315
126
D
(3)
93
0129133
0129
120
120
61015
61015
,
。
(4
)
960412
D
960410
1310406
910406
0
0
315106
315106
max_disdance(v
1
)=12
,<
br>max_disdance(v
2
)=15
,设乡镇
v
i到其他各乡镇的最远距离为
max_disdance(v
i
)
,则有:
max_disdance(v
3
)=10
,
max_disdan
ce(v4)=10
,
max_disdance(v
5
)=15
,
所以可知消防站应建在
v
3
或
v
4
乡镇,才
能使离
消防站最远的乡镇到消防站的路程最短。
五、(本题8分)
【解答】对
n
用归纳法证明。当
n
=
1
时,有
N1=F3-l=2-l=
1
到。当
n=2
时,有
N2=F4-1=3-1=2
。设
n
N
n
=F
n+2
-1
成立。<
br>
当
n=k+1
,对于一个
k+l
层深度的平衡二叉树而言,
其左右子树都是平衡的。结点数为最少的极端情况,
故左右子树中的结点数是不相等的,设其中一个是<
br>k
层深度的二叉平衡树,另一个是
k-l
层深度的二叉平衡树。
所以有
:
N
k+1
=1+N
k
+N
k-1
==
1+(F
k+2
-1)+(F
k+1
-1)=
F
k+2
+F
k+1
-1= F
k+3
-1
当
n=k+1
时成立,由此可知深度为
n
都等式都成立。
六、(本题8分)
【解答】
n
个结点的平衡二叉树的最大高度为
h
log(5(n1))2
,设表示高度需
xbit
,则有关系
15<
br>2
式:
2
x
≥
h
>
2
x-1
,所以有:
x
log
2
h
log
2
(log
15
(5(n
1))2)
2
15
h2
()
2(
2
)设深度为
h
的平衡二叉树的最少关键字数为
n
h
,则有公式:
n1
,本题中
8bit
的计数
h
5
15
258
()
8
2
器共可以表示
2=256
层,即高度为
256
,从而可知最少有
n1
个关键字。
5
七、(本题8分)
【解答】
(
1
)线性探测再散列的哈希表查找成功的平均查找长度
为:
S
nl
也就是
12m
≤
4
/
5
,
所以
m
≥
15
,可取
m=15
。
(
2
)散列函数可取为
H(key)=key % 13
(
3
)散列表如表
7-4
所示。
散列表
0
1
40
2
66
3
94
4
5
5
6
58
7
33
8
47
9
72
10
87
11
22
12
25
13
12
14
11
(1)
≤
3
,解得α≤
4
/
5
,
21
(
4
)
12
个数据
{25,
40
,
33
,
47
,
12
,
66
,
72
,
87
,
94
,
22
,
5
,
58
}的比较次数分别是:
1
,
1
,
1
,
1
,
2
,
2
,
3
,
2
,
1
,
3
,
1
,
1
。
可知查找成功的平均查找次数
=(1+1+1+1+2+2+3+2+1+3+
1+1)12=1.25
八、(本题8分)
【解答】有
n
个叶子结点的带
权路径长度最短的二叉树称哈夫曼树,同理,存在有
n
个叶子结点的带权
路径长度最短
的三叉、四叉、
……
、
k
叉树,也称为哈夫曼树。如叶子结点数目不足以构成
正则的
k
叉树(树
中只有度为
k
或
0
的结点),即
不满足
(n-l)MOD(k-l)=0
,需要添加权为
0
的结点,添加权为
0
的结点的个数
为:
k-(n-1)MOD(k-1)-1
。添加的
位置应该是距离根结点的最远处。
所构造出的哈夫曼树如下图所示:
<
br>其中,每个字母的编码长度等于叶子结点的路径长度,电文的总长度为
wl
=
191
。
ii
i1
n
m=n
k
+n<
br>,注释:对于正则的
k
叉树,设叶结点数为
n
,度为
k
的结点数为
n
k
,结点总数为
m,
则有
m-1=knk
,
两式相减可得
n-1=(k-1)n
k
,即
(n-
l)MOD(k-l)=0
;如
n
与
k
不满足此关系,
n<
br>加上
k-(n-1)MOD(k-1)-1
后,
n’=
n+(k-(n-1)MOD(k-1)-1)
,这时:
(n’-l)MO
D(k-l)=(n+(k-(n-1)MOD(k-1)-1)-l)MOD(k-l)
=((n-1)+(k-1)-(n-1)MOD(k-1))MOD(k-l)
=((n-1)-(n-1)MOD(k-1))MOD(k-l)
=0
。
现有
12
个初始归并段,其记录数分别为{
30,44,8,6,3,20,
60,18,9,62,68,85
},采用
3-
路平衡归并,画出最
佳归并
树。
九、(本题9分)
【解答】设该树中结点总数为
N
,叶子结点个数为
N
0
,则有:
N
N
i0
m
i
i
(
1
)
(
2
)
N1
iN
i1
m
由(
2
)
-
(
1
)再经过移项可得:
N
1
m
(i1)N
0i
i1
十、(本题15分)
【解答】
对
于排列的解空间可构造一个虚拟的解空间树,比如
n=5
,
k=3
时的解空间
树如下图所示,可采用对此
树进行先序遍历方式进行遍历,并用递归法进行递归输出从
n
个数中挑选
k
个进行排列所得序列。
具体算法实现如下:
文件路径名
:exam7alg.h
template
void Arrage(ElemType a[],int k,int
n, int outlen=0)
操作结果
:
回溯法输出排列序列,
a[0..k-1]
为
k
个数的排列序列
outlen
为当
前所求排列
序列的长度,其中
outlen=k
时的排列序列为
所求;
n
为
list
数组长度
{
if (k
< 0 || k >= n) return;
此时无排列
int
i;
临时变量
if (outlen == k + 1)
{
得到一个排列
for (i = 0; i < k;
i++)
{
输出一个排列
cout << a[i];
输出
a[i]
}
cout <<
用空格分隔不同排列
}
else
{
对解空
间进行前序遍历,
a[outlen..n]
有多个排列,递归的生成排列
for (i = outlen; i < n; i++)
{
处理
a[i]
Swap(a[outlen+1], a[i]);
交换
a[outlen+1]
与
a[i]
Arrage(a, k, n, outlen + 1);
对序列长度
outlen+1
递归
Swap(a[outlen+1], a[i]);
交换
a[outlen+1]
与
a[i]
}
}
}
*模拟试题(八)
注:本套试题选作
一、单项选择题(每小题
2 分,共20分)
(
1
)一个
n*n
的带状矩阵
A=[a
ij
]
如下:
a
11
a
21
A
a
12
a
22a
32
a
23
a
33
a
34
a
n2,n1
a
n2,n2
a
n
1,n
a
n2,n1
a
n1,n1
a
n,n1<
br>
a<
br>n1,n
a
nn
将带状区域中的元素
a
ij
(
|i-j|
≤
1
)按行序为主序存储在一维数组
B[3n-2]
中,元素
a
ij
在
B
中的存储位置
是
( )。
A
)
i+2j-2
B
)
2i+j-3 C
)
3i-j
D
)
i+j+1
(
2
)一
n
×
n
的三角矩阵
A=[a
ij
]
如下:
a
11
a
12
a
22
a
1n
a
2n
a
nn
将三角矩阵中元素
a
ij
(i
≤
j)
按行序为主序的顺序存储在一维数组
B[n
(n+1)2]
中,则
a
ij
在
B
中的位置是
(
)。
A
)
(i-1)(2n+i)2+i-j
B
)
(i-1)(2n-i+2)2+j-i
C
)
(i-1)(2n-i)2+j-i-1
D
)
(i-1)(2n-i+2)2+j-i-1
(
3
)设有一
棵度为
3
的树,其叶结点数为
n
0
,度为
1
的结点
数为
n
1
,度为
2
的结点数为
n
2
,度为
3
的
结点数为
n
3
,则
n
0
与<
br>n
1
,
n
2
,
n
3
满足关系(
)。
A
)
n
0
=n
2
+1
B
)
n
0
=n
1
+2n
3
+1
C
)
n
0
=n
2
+n
3
+1 D
)
n
0
=n
1
+n
2
+n
3
<
br>(
4
)
G
是一个非连通无向图,共有
28
条边,则该
图至少有( )个顶点。
A
)
6 B
)
7
C
)
8 D
)
9
(
5
)设图
G
用邻结表存储,则拓扑排序的时间复杂度为(
)。
A
)
O(n) B
)
O(n+e)
C
)
O(n
2
) D
)
O(n×e)
(
6
)用
n
个键值构造一棵二叉排序树,最低高度为(
)。
n
B
)
n
C
)
nlog
2
n
D
)
log
2
n
1
2<
br>(
7
)若需在
O(nlogn)
的时间内完成对数组的排序,且要求排
序是稳定的,则可选择的排序方法是
A
)
( )。
A
)快速排序
B
)堆排序
C
)归并排序
D
)直接插入排序
(
8
)在文件“局部有序”或文件长度较小的情况下,最佳内部排序的方法是(
)。(北方名校经
典试题)
A
)直接插入排序
B
)起泡排序
C
)简单选择排序
D
)基数排序
(
9
)一棵有
124
个叶结点的完全二叉树,最多有(
)个结点。
A
)
247 B
)
248
C
)
249 D
)
250
(
10
)一个序列
中有10000个元素,若只想得到其中前10个最小元素,最好采用 ( )方
法。
A)快速排序 B)堆排序
C)插入排序 D)二路归并排序
二、(本题8分)
要借助栈由输入序列是输入
1,2,3,
…
,n
得到的输出序列为
p
1
,p
2
,p
3
,<
br>…
,p
n
(
此输出序列是输入序列经过栈操作
后的某个排列<
br>)
,则在输出序列中不可能出现当
i
p
j
的情况。
三、(本题8分)
已
知某一完全
k
叉树只有度为
k
的结点及叶结点,设叶结点数为
n0
,试求它的树高
h
。(南方名校经典
试题)
四、(本题8分)
试讨论怎样在一棵中序线索二叉树上查找给定结点
x
在后序序列中的后继。
五、(本题8分)
具有
n
个关键字的
B
一树的查找的最大路径长度是多少?
六、(本题8分)
对长度为
12
的有序表
(a
1
,
a
2
,…,
a
12
)
(其中
a
i
j
当
i
x1
、
x>a
12
以及
a
i
(i=1,2,…,11)
等情况发生的概率相等,则查找不
成功的平均查找长度是多少?
八、(本题8分)
(
1
)设
T
是具有
n
个内结点的判断二叉树,
I
是它的内路径长度,
E
是它的外路径长度,试利用归纳法
证明
E
=
I
+2n
,
n
>
0
。
(
2
)利
用(
1
)的结果,试说明,成功查找的平均比较次数
s
与不成功查找的平均比
较次数
u
之间的关
系,可用公式
s(1
1
n
)
u1
,
n
>
0
表示。
提示:判断二叉树只有度
为
0
或度为
2
的结点;判断二叉树成功查找的比较次数为内路径长度与内结点
数之和,不成功查找的比较次数为外路径长度。
九、(本题9分)
一个深
度为
h
的满
m
叉树有如下性质:第
h
层上的结点都是叶结点
,其余各层上每个结点有
m
棵非空子
树。问:
(
1
)第
k
层有多少个结点?(
k
≤
h
)
(
2
)整棵树有多少个结点?
(
3
)若按层次从
上到下,每层从左到右的顺序从
1
开始对全部结点编号,编号为
i
的结点的双
亲结点的编号
是什么?编号为
i
的结点的第
j
个孩子结点(若存在)
的编号是什么?
十、(本题15分)
设散列表的关键字取值范围为
0 ~
m-1
,
n
为对散列表的最大插入次数,设计散列表,允许使用以
O(m+n
)
空间,要求查找、插入和删除算法的时间复杂度都是
O(1)
。
模拟试题(八)参考答案
一、单项选择题(每小题 2 分,共20分)
(
1
)参考答案:
B
)
(
2
)
【分析】存储位置
=n+(n-1)+…+(n-i+2)+i-j=(i-1)(2n-i+2)2+
j-i
。
参考答案:
B
)
(
3
)【分析】用
n
表示结点总数,则有:
n=
n
0
+n
1
+n
2
+n
3
;
由于除根结点而外,结点与分支一一对应,而分支数
=
n
1
+2n
2
+3n
3
,即有:
n-1=
n
1
+2n
2
+3n
3
。
由上面两式可
得:
n
0
=n
1
+2n
3
+1
参考答案:
B
)
(
4
)【分析】本题中由于是非
连图,至少有一个顶点与其他顶点不连,这个顶点是孤立点,其他顶点可
组成一个连通图,由于
8
个顶点的完全图共有
28
条边,所以具体
28
个顶点的连通图的顶
点个数至少为
8
,这
样非连通图至少有
9
个顶点。
参考答案:
D
)
(
5
)【分析】对于有
n
个顶点
e
条边的有向图,建立各顶点的入度时间复杂度为
O(e)
,建立入度为零的
栈的时间复杂度为
O(n)
,在拓扑排序过程中,最多每个顶点进一
次栈,入度减
1
的操作最多总共执行
e
次,
可知总的时间复杂度为<
br>O(n+e)
参考答案:
B
)
(
6<
br>)【分析】当用
n
个键值构造一棵二叉排序树是一棵完全二叉树时,高度最低,此时高度
为
log
2
n
1
。
参考答案:D
)
(
7
)【分析】快速排序和堆排序都是不稳定的,应排除
;归并排序稳定,时间复杂度
O(nlogn)
,满足条
件;直接插入排序,时间复杂
度为
O(n
2
)
,排除。
参考答案:
C
)
(
8
)【分析】对直接插入排序
而言,算法时间复杂度为
O(n
2
)
,但若待排记录序列为“正序”时,其时
间复杂度可提高至
O(n)
。若待排记录序列按关键字“基本有序”,直接插入排序的
效率就可大大提高,此外
由于直接插入排序算法简单,在
n
值很小时效率也高。
参考答案:
A
)
(
9
)【分析】完全二
叉树中度为
1
的结点最多只有
1
个,由二叉树的度和结点的关系:
n=n
0
+n
1
+n
2
(1)
n=n
1
+2n
2
+1
(2)
<
br>由
2(1)-(2)
得,
n=2n
0
+n
1
-1=247+n
1
≤
248
,所以本题应选择
B
)。
参考答案:
A
)
(
10
)参考答案:
B
)
二、(本题8分) <
br>【解答】设
p
j
成立,则表示
在
p
i
出栈之前
p
j
和
p
k
都已
入栈,并且还留在栈中,但要满足
p
j
的出
栈次序是
不可能的,由于按照
i
p
j
和
p
k
同时在栈中时,必然
p
k
被
p
j
盖住,由栈的
后进先出的
性质,当
i
p
k
<
p
j
,与假设矛盾。
三、(本题8分)
【解答】设度为
k
的结点数为
n
k
,结点总数为
n
,则有如下关系:
n= n
k
+n
0
又由于树中只有
n-1
条边,所以:
n-1=k
×
n
k
由①与②可得:
n
k
=(n
0
-1)
(k-1)
,进而有
n=
①
②
kn
0
1
k1
(k-1)
≤
k
h
-1
对于
k<
br>叉完全树有如下关系:
k
h-1
-1
<
n×
(k-1
)
<
k
h
,从而:
h-1
≤
log
k(n×(k-1))
<
h
,进而:
h
log
k
(n(k1))
1
即有:
k
h-1
≤
n×
所以:
h=
log
k
(kn<
br>0
1)
1
四、(本题8分)
【解答】由于
后序遍历二叉树需要知道的关键是访问当前结点的双亲结点,需要由中序线索树才能得到
当前结点的双亲
,中序线索树有如下性质:
若
x
是
parent
的左孩子
,则
parent
是
x
的最右子孙的右线索;
若
x
是
parent
的右孩子,则
parent
是
x
的最左子孙的左线索。
用以上性质能找到
x
的双亲结点
parent
。
若
x
是
parent
的右孩子,则
parent
结点就是<
br>x
的后序序列的后继结点;如下图(
1
)中结点①的后继是结
点②。<
br>
若
x
是
parent
的左孩子,则:
如
果
parent
的右指针域为线索的话,那么
parent
就是
x<
br>的后序序列的后继结点,如下图(
2
)中结点②的
后继是结点③。
否则
parent
右子树中最左边第一个左右孩子均为线索的结点,就是
x
的后序序列的后继结点。如下图(
3
)
中结点②的后继是结点③。
五、(本题8分)
【解答】树的查找路径是从根结点开始到所要查找的结点的路径
,最大不会超过
B-
树的深度。在
B
树中,
除根结点外所有非终端结
点都含有
m
棵子树,所以有
n
个关键字的<
br>B-
树的最大深度为根结点具有两棵子
2
树,
其余非终端点有
m
棵子树,设最大路径长度是
x,由于叶子结点表示查找不成功,叶子结点不含关键
2
字,可知<
br>B-
树的深度为
x+1
,
第
1
层共有
1
个结点,含
1
个关键字;
第
2
层共有
2
个结点,含
2(
m
-1)
个关键字;
2
第
3
层共有
2
……
m
m
m
2(-1)
个关键字;
个结点,含
222
x2
m
第
x
层共有
2
2
m
个结点,含
2
2
x2
(
m
-1)
个关键字;
2
m
m
(-1)
=
2
2
2
x1
故,共含有的关键个数为:
m<
br>
m
m
m
1+2(-
1)+2(-1)+
…
+2
2
2
2
2
x2
1
m
由此可得:
n2
2
x1
1
,解得:<
br>x1log
m
(
2
n1
)
,这就是具有
n
个关键宇的
B
一树的查
2
找的最大路径长度。
六、(本题8分)
【解答】折半查找对应
的判定树如下图所示。查找不成功的对应于外部结点。查找不成功所走的路径是
从根结点到每个外部结点
(图中方块结点),和给定值进行比较的关键字个数等于该路径上内部结点个数。
在不成功情况下,一共比较的次数为
3*3+4*10=49
次。
平均查找长度为
4913
≈
3.77
七、(本题8分)
【解答】对于
a
来说,在
S2
中总可找到离
a
最近的祖先结
点
d
,这时
a
d
为
b
的右孩
子,则
有
a
在
b
的右子树上,所以
a>b
,也就是
说
a并不总是成立,同理
b
八、(本题8分)
【解答】
(
1
)证明:
n=1
时显然成立,设
n=k
时成立,即
E
k
=I
k
+
2k
,当
n=k+1
时,设所增加的结点的路径长度
为
D<
br>k
,则有:
I
k+1
=I
k
+D
k
E
k+
1
=E
k
-D
k
+2(D
k
+1)=E
k
+D
k
+2=I
k
+2k+D
k
+2=I
k+1
+2(k+1)=I
k+1
+2n
结论也成立。
(
2
)根据二叉树性质:度为
0
的结点数
=
度为
2
的结点数
+1
,所以外结点数
=n
+
l
。
s=
查找成功总的比较次数
内结点数
=(I+n)n
①
u=
查找失败总的比较次数
外结点数
=E(n
+1)=(I+2n)(n+1)
②
由①得:
I=ns-n
,由②得:
I=(n+1)u-2n
,所以可得:
ns-n=(n+1)u-2n,进一步得:
s(1
1
n
)u1
。
九、(本题9分)
【解答】
(
1
)设第<
br>v
层有
u
个结点
(m
v
层
的每个结点有
m
个孩子,所以第
v+1
层的结点个数为
mu
。
第
1
层有
1
个结点,第
2
层有
m
个结点,第
3
层有
m
2
结点,用数学归纳法易知
k
层共有
m
k-1
个结点。
m
h
1
(
2
)整棵树结点数
=1+m+m+
…
+m=
。<
br>
m1
2h-1
(
3
)设编号为
i
的结点
双亲的结点编号为
x
,将编号为
i
的结点视为完全二叉树的最后一个结点,因
此,
此完全
m
叉树中至少有
x-l
个度为
m
的结点,而
x
号结点的度
d
(
1
≤
d
≤
m
),其余的结点均为叶子结点,
而编号
i
就是此完全
m
又树的总结局数,于是有:
(x-1)m+d+1=i
所以有
x
imd1
,由于
1
≤
d
≤
m<
br>,所以有:
m
im2imim2
11
x
mmm
可知:
x
im2
。
m
设编号为
i
的第
j
个
子结点为完全
m
叉树的最后一个结点
n
,此完全
m
叉树中有
i-1
个度为
m
的结点,
m+j+1
一个度为
j
的结点,其他结点均为叶子结点,可得:
n=(i-l)×
十、(本题15分) 【解答】在理想情况下,可实现散列表查找、插入、删除操作的操作时间为
O(1)
,对于
本题,由于已经知道了
关键字的取值范和散列表的最大插入次数,可作理想化处理哈希方法:将查找与数
据在一起的哈希表一分为二:采
用两个数组
ht
和
elem
,其中
ht
是从
0
到
m-1
的整数数组
(做索引用);
elem
数组的数据类型为哈希表中各元素的
类型,其元素个数为n
(即最大的插入次数),两个数组都不需要初始化。使用计数器
lastE
表示
上次所用到的
elem
中的位置,初值为
-1
。
ht[k]
中的值可能无效(用
-1
表示)也可能是
elem
的索引(用来寻找关键字为
k
的元素),如
下图所示:
具体算法实现当如下:
文件路径名
:exam8alg.h
理想散列表类
template
class IdealHashTable
{
protected:
散列表的的数据成员
:
int *ht;
用作
elem
的索引
ElemType *elem;
在放插入的哈希表的元素
int
lastE;
计数器,表示上次用到的
elem
位置
int n;
最大插入次数
int m;
关键字范围
0~m-1
public:
理想散列表方法声明及重载编译系统默认方法声明
:
IdealHashTable(int maxInsertCount, int size);
构造函数
~IdealHashTable();
析造函数
void Traverse(void
(*Visit)(const ElemType &)) const;
遍历散列表
bool Search(const KeyType &key, ElemType &e)
const;
查寻关键字为
key
的元素
bool
Insert(const ElemType &e);
插入元素
e
bool Delete(const KeyType &key, ElemType &e);
删除关键字为
key
的元素,用
e
返回元素值
IdealHashTable(const IdealHashTable
复制构造函数
IdealHashTable
(const IdealHashTable
赋值语句重载
};
理想散列表类的实现部分
template
IdealHashTable
操作结果
:
构造最大插入次数为
maxInsertCount,
关键字范围为
0~size-1
的空理想散列表
{
n
= maxInsertCount;
最大插入次数
m = size;
关键字范围为
0~size-1
ht = new int[n];
为
elem
索引表分配存储空间
elem = new
ElemType[m];
为元素分配存储空间
lastE = -1;
初始化
lastE
for (int pos = 0; pos < n;
pos++)
{
初始化
ht
ht[pos] = -1;
}
}
template
IdealHashTable
操作结果
:
销毁散列表
{
delete []ht;
释放
ht
delete []elem;
释放
elem
}
template
void
IdealHashTable
操作结果
:
依次对散列表的每个元素调用函数
(*visit)
{
for (int pos = 0; pos < m; pos++)
{
对散列表的每个元素调用函数
(*visit)
if (ht[pos] != -1) (*Visit)(elem[ht[pos]]);
}
}
template
bool IdealHashTable
初始条件
:
关键字
key
的范围为
0~m-1
,
ht[key]
的范围为
0~lastE
操作结果
:
查寻关键字为
key
的元素的值
,
如
果查找成功
,
返回
true,
并用
e
返回元素的值
,
否则返回
false
{
if (key < 0
|| key >= m)
{
范围错
return
false;
查找失败
}
else if
(ht[key] < 0 || ht[key] > lastE || elem[ht[key]]
!= key)
{
表中没有要查找的元素
return
false;
查找失败
}
else
{
存在要查找的元素
e = elem[ht[key]];
用
e
返回元素值
return true;
查找成功
}
}
template
bool
IdealHashTable
操作结果
:
将元素插入到
elem
数组
lastE
位置,同时修改索引值
{
KeyType key = e; e
的关键字
ElemType
eTmp;
临时变量
if (key < 0 || key >=
m)
{
范围错
return false;
插入失败
}
else if (Search(key,
eTmp))
{
查找成功
return false;
插入失败
}
else if (lastE == n - 1)
{
超过最大插入次数
return false;
插入失败
}
else
{
elem[++lastE] = e;
修改计数器,将元素插入到表中
ht[key] = lastE;
索引表
ht
中
ht[key]记录关键字为
key
的元素在
elem
中的位置
return true;
插入成功
}
}
template
bool IdealHashTable
操作结果
:
删除关键字为
key
的数据元素
,
删除成功返回
true,
并用
e
返回元素值,否则返回
fa
lse,
通过将
lastE
位置元素移到删除位置,
lastE
指向倒数第二个元素,从逻辑上完成删除
{
if
(!Search(key, e))
{
查找失败
return false;
删除失败
}
else
{
查找成功
e = elem[ht[key]];
用
e
返回被删除元素值
elem[ht[key]] =
elem[lastE--];
将最后元素移到所删除处
,
将修改
Las
tE
指向新的末记录
int k = elem[ht[key]];
原最后元素的关键字
ht[k] = ht[key];
修改索引值
ht[key] = -1;
修改
ht
[key]
为
-1
,表示关键字为
key
的元素已初删除
return true;
删除成功
}
}
template
IdealHashTable
const
IdealHashTable
操作结果:由散列表
copy
构造新散列表
--
复制构造函数
{
n = copy.n;
最大插入次数
m
= copy.m;
关键字范围为
0~m-1
ht = new
int[n];
为
elem
索引表分配存储空间
elem = new ElemType[m];
为元素分配存储空间
lastE =
计数器,表示上次用到的
elem
位置
int pos;
临时变量
for
(pos = 0; pos < m; pos++)
{
复制元素索引
ht[pos] = [pos];
复制元素索引值
}
for (pos = 0; pos < m; pos++)
{
依次复制数据元素
elem[pos] = [pos];
复制元素值
}
}
template
IdealHashTable
operator=(const IdealHashTable
操作结果:将散列表
copy
赋值给当
前散列表
--
赋值语句重载
{
if (© !=
this)
}
{
delete []ht;
delete []elem;
释放
ht
释放
elem
最大插入次数
关键字范围为
0~m-1
为
elem
索引表分配存储空间
为元素分配存储空间
计数器,表示上次用到的
elem
位置
n = copy.n;
m = copy.m;
ht = new int[n];
elem = new ElemType[m];
lastE =
int pos;
临时变量
for (pos = 0; pos
< m; pos++)
{
复制元素索引
ht[pos] =
[pos];
复制元素索引值
}
for (pos = 0;
pos < m; pos++)
{
依次复制数据元素
elem[pos] = [pos];
复制元素值
}
}
return *this;
流动人口管理-学生转正申请书范文
元旦的来历简介-国际法试题
环境管理体系认证-陈情表原文
镜子中-重阳节的诗