s+=i*j;
A.O
(1)B.O(n)
C.O(2n)D.O(n2)
2.假设某个带头结点的单链表的头指针为head,则判定该表为空表的条件是()22
A.head==NULL;B.head->next==NULL;
C.head!
=NULL;D.head->next==head;
3.栈是一种操作受限的线性结构,其操作的主要特征是()32
A.先进先出B.后进先出
C.进优于出D.出优于进
4.假设以数组A[n]存放循环队列的元素,其头、尾指针分别为front和rear。
若设定尾指针指向队列中的队尾元素,头指针指向队列中队头元素的前一个位置,则当前存于队列中的元素个数为()
A.(rear-front-1)%nB.(rear-front)%n
C.(front-rear+1)%nD.(rear-front+n)%n
5.判断两个串大小的基本准则是()52
A.两个串长度的大小B.两个串中首字符的大小
C.两个串中大写字母的多少D.对应的第一个不等字符的大小
6.二维数组A[4][5]按行优先顺序存储,若每个元素占2个存储单元,且第一个元素A[0][0]的存储地址为1000,则数组元素A[3][2]的存储地址为()60
A.1012B.1017
C.1034D.1036
a00
a01
a02
a03
a04
a32
7.高度为5的完全二叉树中含有的结点数至少为()72
A.16B.17
C.31D.32
8.已知在一棵度为3的树中,度为2的结点数为4,度为3的结点数为3,则该树中的叶子结点数为()
A.5B.8
C.11D.18
9.下列所示各图中是中序线索化二叉树的是()81A
10.已知含6个顶点(v0,v1,v2,v3,v4,v5)的无向图的邻接矩阵如图所示,则从顶点v0出发进行深度优先遍历可能得到的顶点访问序列为()108
A.(v0,v1,v2,v5,v4,v3)
B.(v0,v1,v2,v3,v4,v5)
C.(v0,v1,v5,v2,v3,v4)
D.(v0,v1,v4,v5,v2,v3)
11.如图所示有向图的一个拓扑序列是()
A.ABCDEF
B.FCBEAD
C.FEDCBA
D.DAEBCF
12.下列关键字序列中,构成大根堆的是()
A.5,8,1,3,9,6,2,7B.9,8,1,7,5,6,2,33
C.9,8,6,3,5,l,2,7D.9,8,6,7,5,1,2,3
13.对长度为15的有序顺序表进行二分查找,在各记录的查找概率均相等的情况下,查找成功时所需进行的关键字比较次数的平均值为()172
A.
B.
C.
D.
14.已知一个散列表如图所示,其散列函数为H(key)=key%11,采用二次探查法处理冲突,则下一个插入的关键字49的地址为()d197
15.数据库文件是由大量带有结构的()206
A.记录组成的集合B.字符组成的集合
C.数据项组成的集合D.数据结构组成的集合
二、填空题(本大题共10小题,每小题2分,共20分)
请在每小题的空格中填上正确答案。
错填、不填均无分。
16.估算算法时间复杂度时考虑的问题规模通常是指算法求解问题的_________。
输入量8
17.在双向循环链表中插入一个新的结点时,应修改_________个指针域的值。
428
18.若进栈序列为a,b,c,且进栈和出栈可以穿插进行,则可能出现_________个不同的出栈序列。
5
19.链串的结点大小定义为结点的_________中存放的字符个数。
数据域54
20.广义表(a,(d,(c)))的深度为_________。
367
21.在含有3个结点a,b,c的二叉树中,前序序列为abc且后序序列为cba的二叉树有_________棵。
4
22.若用邻接矩阵表示有向图,则顶点i的入度等于矩阵中_________。
第i列非零元素的个数107
23.对关键字序列(15,18,11,13,19,16,12,17,10,8)进行增量为5的一趟希尔排序的结果为_________。
15,12,11,10,8,16,18,17
24.索引顺序查找的索引表由各分块中的最大关键字及各分块的_________构成。
起始位置173
25.VSAM文件的实现依赖于操作系统中的_________存取方法的功能。
分页215
三、解答题(本大题共4小题,每小题5分,共20分)
26.假设有一个形如
的8×8矩阵,矩阵元素都是整型量(次对角线以上的元素都是0)。
若将上述矩阵中次对角线及其以下的元素按行优先压缩存储在一维数组B中,请回答下列问题:
(1)B数组的体积至少是多少?
(2)若a18存储在B[0]中,a56存储在B[k]中,则k值为多少?
(1)(1+8)*8/2=36存放次对角线以上的零为37
(2)12
27.对关键字序列(5,8,1,3,9,6,2,7)按从小到大进行快速排序。
(1)写出排序过程中前两趟的划分结果;
(2)快速排序是否是稳定的排序方法?
(1)
第一趟划分结果;(2,3,1),5,(9,6,8,7)
第二趟划分结果;(1,2,3),5,(9,6,8,7)
第三趟划分结果;(1,2,3),5,(7,6,8,9)
第四趟划分结果;1,2,3,5,6,7,8,9
第一趟划分过程
2
3
1
5
9
6
8
7
1
2
3
5
9
6
8
7
1
2
3
5
7
6
8
9
1
2
3
5
6
7
8
9
↑j
↑i
(5,8,1,3,9,6,2,7)
1.(2,8,1,3,9,6,5,7)
2.(2,5,1,3,9,6,8,7)
3.(2,3,1,5,9,6,8,7)
4.(2,3,1,5,9,6,8,7)
第二趟划分过程
(2,3,1,5,9,6,8,7)
1.(1,2,3,5,7,6,8,9)
(2)非稳定
2
3
1
5
9
6
8
7
1
2
3
5
5
7
6
8
9
5
6
7
8
9
↑j
↑i
第一趟:
(2,3,1)5(9,6,8,7)
第二趟:
1,2,3,5(9,6,8,7)
第三趟:
1,2,3,5,(7,6,8),9
第四趟:
1,2,3,5,6,7,8,9
28.假设通信电文使用的字符集为{a,b,c,d,e,f,g,h},各字符在电文中出现的频度分别为:
7,26,2,28,13,10,3,11,试为这8个字符设计哈夫曼编码。
要求:
(1)画出你所构造的哈夫曼树(要求树中左孩子结点的权值不大于右孩子结点的权值);
(2)按左分支为0和右分支为1的规则,分别写出与每个字符对应的编码。
(1)
(2)
29.已知3阶B—树如图所示,
非根【1,2】P184
根【1,2】
(1)画出将关键字6插入之后的B—树;
(2)画出在
(1)所得树中插入关键字2之后的B—树。
四、算法阅读题(本大题共4小题,每小题5分,共20分)
30.假设以带头结点的单链表表示线性表,单链表的类型定义如下:
typedefintDataType;
typedefstructnode{
DataTypedata;
structnode*next;
}LinkNode,*LinkList;
阅读下列算法,并回答问题:
(1)已知初始链表如图所示,画出执行f30(head)之后的链表;
题30图
(2)简述算法f30的功能。
voidf30(LinkListhead)
{LinkListp,r,s;
if(head->next){
r=head->next;
p=r->next;
r->next=NULL;
while(p){
s=p;
p=p->next;
if(s->data%2==0){
s->next=head->next;
head->next=s;
}else{
s->next=r->next;
r->next=s;
r=s;
}
}
}
}
(1)
(2)
31.假设以二叉链表表示二叉树,其类型定义如下:
typedefstructnode{
DataTypedata;
structnode*lchild,*rchild;//左右孩子指针
}*BinTree;
阅读下列算法,并回答问题:
(1)已知以T为根指针的二叉树如图所示,
写出执行f31(T)之后的返回值;
(2)简述算法f31的功能。
intf31(BinTreeT)
{intd;
if(!
T)return0;
d=f31(T->lchild)+f31(T->rchild);
if(T->lchild&&T->rchild)
returnd+1;
else
returnd;
(1)3
(2)统计度为2的结点个数
32.设有向图邻接表定义如下:
typedefstruct{
VertexNodeadjlist[MaxVertexNum];
intn,e;//图的当前顶点数和弧数
}ALGraph;//邻接表类型
其中顶点表结点VertexNode
边表结点EdgeNode结构为:
阅读下列算法,并回答问题:
(1)已知某有向图存储在如图所示的邻接
表G中,写出执行f32(&G)的输出;
(2)简述算法f32的功能。
intvisited[MaxNum];
voidDFS(ALGraph*G,inti){
EdgeNode*p;
visited[i]=TRUE;
if(G->adjlist[i].firstedge==NULL)
printf("%c",G->adjlist[i].vertex);
else{
p=G->adjlist[i].firstedge;
while(p!
=NULL){
if(!
visited[p->adjvex])
DFS(G,p->adjvex);
p=p->next;
}
}
}
voidf32(ALGraph*G){
inti;
for(i=0;in;i++)
visited[i]=FALSE;
for(i=0;in;i++)
if(!
visited[i])DFS(G,i);
}
(1)ABECD
(2)图的深度优先搜寻
33.下列算法f33的功能是对记录序列进行双向冒泡排序。
算法的基本思想为,先从前往后通过交换将关键字最大的记录移动至后端,然后从后往前通过交换将关键字最小的记录移动至前端,如此反复进行,直至整个序列按关键字递增有序为止。
请在空缺处填入合适的内容,使其成为完整的算法。
#defineMAXLEN100
typedefintKeyType;
typedefstruct{
KeyTypekey;
InfoTypeotherinfo;
}NodeType;
typedefNodeTypeSqList[MAXLEN];
voidf33(SqListR,intn)
{inti,j,k;
NodeTypet;
i=0;
j=n-l;
while(ifor(
(1))k=i;kif(R[k].key>R[k+l].key){
t=R[k];
R[k]=R[k+1];
R[k+1]=t;
}
j--;
for(k=j;k>i;k--)
if(
(2)){R[k].keyt=R[k];
R[k]=R[k-1];
R[k-1]=t;
}
(3);i++
}
}
(1)
(2)
(3)
五、算法设计题(本大题10分)
34.假设以带头结点的单链表表示线性表,单链表的类型定义如下:
typedefintDataType;
typedefstructnode{
DataTypedata;
structnode*next;
}LinkNode,*LinkList;
编写算法,删除线性表中最大元素(假设最大值唯一存在)。
函数原型为:
voidf34(LinkListhead)
{
LinkNode*p,*max,*q;
P=head->next;
max=head->next;
while(P)
{
P=p->next;
If(p->data>max->data)max=p;
}
x=max->data;
}
}
delete_L(Lnode*L,inti)
{Lnode*p,*q;
intj;
Elemtypex;
P=L;j=0;
While(p->next!
=null&&j<=i-1)
{p=p->next;j++;}
If(!
P->next||i<1)
{Printf("\n删除位置错误!
");return(-1);}
Else{q=p->next;x=q->data;
P->next=q->next;free(q);
Return(x);
}
}/*delete_L*/