if(j==strlen(t))return(i-strlen(t));elsereturn(-1);
}
设一个连通图
G中有
n个极点
e条边,则其最小生成树上有
________条边。
二、填空题
10.(F+1)%m
11.O(n),O(n)
12.2n,n+1
13.s->next=p->next;s->next=s
14.n,2e
15.m=2e
16.CBA
17.4,16
18.i-j+1,0
19.n-1
20.
三、应用题(30分)
1.设完整二叉树的次序储存结构中储存数据ABCDE,要求给出该二叉树的链式储存结构并给出该二叉树
的前序、中序和后序遍历序列。
2.设给定一个权值会合W=(3,5,7,9,11),要求依据给定的权值会合结构一棵哈夫曼树并计算哈夫
曼树的带权路径长度WPL。
3.设一组初始记录重点字序列为
为基准的一趟迅速排序结果以及第
(19,21,16,5,18,23),要求给出以
2趟直接选择排序后的结果。
19
4.设一组初始记录重点字会合为(25,10,8,27,32,68),散列表的长度为
8,散列函数H(k)=kmod7,要求分别用线性探测和链地点法作为解决矛盾的方法设计哈希表。
5.设无向图G(所右图所示),要求给出该图的深度优先和广度优先遍历的序列并给出该图的最小生成树。
三、应用题
1.链式储存结构略,前序ABDEC,中序DBEAC,后序DEBCA。
2.哈夫曼树略,WPL=78
3.(18,5,16,19,21,23),(5,16,21,19,18,23)
h0
h1
8
0
1
2
3
4
5
6
7
h2
4.
链地点法:
h3
10
线性探测:
8
10
25
32
27
68
h4
25
32
h5
68
h6
27
5.
深度:
125364,广度:
123456,最小生成树
T的边集为E={(1
,4),(1,3),(3,5),(5,6),(5,6)}
四、算法设计题(20分)
1.设计判断单链表中结点能否对于中心对称算法。
2.设计在链式储存结构上成立一棵二叉树的算法。
3.设计判断一棵二叉树是不是二叉排序树的算法。
四、算法设计题
1.设计判断单链表中结点能否对于中心对称算法。
typedefstruct{ints[100];inttop;}sqstack;
intlklistsymmetry(lklist*head)
{
sqstackstack;stack.top=-1;lklist*p;for(p=head;p!
=0;p=p->next){stack.top++;stack.s[stack.top]=p->data;}
for(p=head;p!
=0;p=p->next)if(p->data==stack.s[stack.top])stack.top=stack.top-1;elsereturn(0);return
(1);
}
2.设计在链式储存结构上成立一棵二叉树的算法。
typedefchardatatype;
typedefstructnode{datatypedata;structnode*lchild,*rchild;}bitree;voidcreatebitree(bitree*&bt)
{
charch;scanf("%c",&ch);if(ch=='#'){bt=0;return;}bt=(bitree*)malloc(sizeof(bitree));bt->data=ch;createbitree(bt->lchild);createbitree(bt->rchild);
}
3.设计判断一棵二叉树是不是二叉排序树的算法。
intminnum=-32768,flag=1;
typedefstructnode{intkey;structnode*lchild,*rchild;}bitree;voidinorder(bitree*bt)
{
if(bt!
=0)
{inorder(bt->lchild);if(minnum>bt->key)flag=0;minnum=bt->key;inorder(bt->rchild);}
}
数据结构试卷
(一)参照答案
数据结构试卷
(二)
一、选择题(24分)
1.下边对于线性表的表达错误的选项是()。
(A)线性表采纳次序储存一定占用一片连续的储存空间
(B)线性表采纳链式储存不用占用一片连续的储存空间
(C)线性表采纳链式储存便于插入和删除操作的实现
(D)线性表采纳次序储存便于插入和删除操作的实现
2.设哈夫曼树中的叶子结点总数为
m,若用二叉链表作为储存结构,则该哈夫曼树中总合有(
)个空
指针域。
(A)2m-1
(B)2m
(C)2m+1
(D)4m
3.设次序循环行列
Q[0:
M-1]的头指针和尾指针分别为
F和R,头指针F老是指向队头元素的前一地点,
尾指针R老是指向队尾元素的目前地点,则该循环行列中的元素个数为(
)。
(A)R-F
(B)F-R
(C)(R-F+M)%M
(D)(F-R+M)%M
4.设某棵二叉树的中序遍历序列为
ABCD,前序遍历序列为
CABD,则后序遍历该二叉树获得序列为
(
)。
(A)BADC
(B)BCDA
(C)CDAB
(D)CBDA
5.设某完整无向图中有n个极点,则该完整无向图中有(
)条边。
(A)n(n-1)/2
(B)n(n-1)
(C)n2
(D)n
2-1
6.设某棵二叉树中有
2000个结点,则该二叉树的最小高度为(
)。
(A)9
(B)10
(C)11
(D)12
7.设某有向图中有
n个极点,则该有向图对应的毗邻表中有(
)个表头结点。
(A)n-1
(B)n
(C)n+1
(D)2n-1
8.设一组初始记录重点字序列(5,2,6,3,8),以第一个记录重点字
5为基准进行一趟迅速排序的结
果为(
)。
(A)2
,3,5,8,6
(B)3
,2,5,8,6
(C)3
,2,5,6,8
(D)2
,3,6,5,8
二、填空题(24分)
1.为了能有效地应用HASH查找技术,一定解决的两个问题是____________________和
__________________________。
2.下边程序段的功能实现数据x进栈,要求在下划线处填上正确的语句。
typedefstruct{ints[100];inttop;}sqstack;voidpush(sqstack&stack,intx)
{
if(stack.top==m-1)printf(“overflow”);
else{____________________;_________________;}
}
3.中序遍历二叉排序树所获得的序列是
___________序列(填有序或无序)。
4.迅速排序的最坏时间复杂度为___________,均匀时间复杂度为__________。
5.
设某棵二叉树中度数为0的结点数为N0,度数为1的结点数为N1,则该二叉树中度数为
2的结点数
为_________;若采纳二叉链表作为该二叉树的储存结构,则该二叉树中共有
_______个空指针域。
6.
设某无向图中极点数和边数分别为
n和e,全部极点的度数之和为
d,则e=_______。
7.设一组初始记录重点字序列为(55,63,44,38,75,80,31,56),则利用挑选法成立的初始堆为
___________________________。
v1
3
2
4
8.设某无向图
v2
1
3
,则从极点V开始的深度优先遍历序列为
___________;
G的毗邻表为
1
v3
1
4
2
v4
1
3
广度优先遍历序列为
____________。
三、应用题(36分)
1.设一组初始记录重点字序列为(45,80,48,40,22,78),则分别给出第4趟简单项选择择排序和第
趟直接插入排序后的结果。
2.设指针变量p指向双向链表中结点A,指针变量q指向被插入结点B,要求给出在结点A的后边插入
结点B的操作序列(设双向链表中结点的两个指针域分别为llink和rlink)。
3.设一组有序的记录重点字序列为(13,18,24,35,47,50,62,83,90),查找方法用二分查找,
4
要求计算出查找重点字62时的比较次数并计算出查找成功时的均匀查找长度。
4.设一棵树T中边的会合为{(A,B),(A,C),(A,D),(B,E),(C,F),(C,G)},要求用孩子兄弟表示法(二叉链表)表示出该树的储存结构并将该树
转变为对应的二叉树。
5.设有无向图G(如右图所示),要求给出用普里姆算法结构最小生成树所走
过的边的会合。
6.设有一组初始记录重点字为(45,80,48,40,22,78),要求结构一棵二叉排序树并给出结构过程。
四、算法设计题(16分)
1.设有一组初始记录重点字序列(K1,K2,,Kn),要求设计一个算法能够在O(n)的时间复杂度内将
线性表区分红两部分,此中左半部分的每个重点字均小于Ki,右半部分的每个重点字均大于等于Ki。
2.设有两个会合A和会合B,要求设计生成会合C=A∩B的算法,此中会合A、B和C用链式储存结构
表示。
数据结构试卷
(二)参照答案
一、选择题
1.D2.B3.C4.A5.A6.C7.B8.C
二、填空题
1.结构一个好的HASH函数,确立解决矛盾的方法
2.stack.top++,stack.s[stack.top]=x
3.有序
4.O(n2),O(nlog2n)
5.N0-1,2N0+N1
6.d/2
7.(31,38,54,56,75,80,55,63)
8.(1,3,4,2),(1,3,2,4)
三、应用题
1.(22,40,45,48,80,78),(40,45,48,80,22,78)
2.q->llink=p;q->rlink=p->rlink;p->rlink->llink=q;p->rlink=q;
3.2,ASL=91*1+2*2+3*4+4*2)=25/9
4.树的链式储存结构略,二叉树略
5.E={(1,3),(1,2),(3,5),(5,6),(6,4)}
6.略
四、算法设计题
1.设有一组初始记录重点字序列(K1,K2,,Kn),要求设计一个算法能够在O(n)的时间复杂度内将
线性表区分红两部分,此中左半部分的每个重点字均小于Ki,右半部分的每个重点字均大于等于Ki。
voidquickpass(intr[],ints,intt)
{
inti=s,j=t,x=r[s];
while(iwhile(ix)j=j-1;if(iwhile(i}
r[i]=x;
}
2.设有两个会合
A和会合
B,要求设计生成会合
C=A∩B的算法,此中会合
A、B和
C用链式储存结构
表示。
typedefstructnode{intdata;structnode*next;}lklist;
voidintersection(lklist*ha,lklist*hb,lklist*&hc)
{
lklist*p,*q,*t;
for(p=ha,hc=0;p!
=0;p=p->next)
{for(q=hb;q!
=0;q=q->next)if(q->data==p->data)break;
if(q!
=0){t=(lklist*)malloc(sizeof(lklist));t->data=p->data;t->next=hc;hc=t;}
}
}
数据结构试卷(三)
一、选择题(30分)
1.设某数据结构的二元组形式表示为A=(D,R),D={01,02,03,04,05,06,07,08,09},R={r},
r={<01,02>,<01,03>,<01,04>,<02,05>,<02,06>,<03,07>,<03,08>,<03,09>},
则数据结构A是()。
(A)线性结构
(B)树型结构
(C)物理结构
(D)图型结构
2.下边程序的时间复杂为(
)
for(i=1,s=0;i<=n;i++){t=1;for(j=1;j<=i;j++)t=t*j;s=s+t;}
(A)O(n)
(B)O(n
2)
(C)O(n
3)
(D)O(n4)
3.设指针变量p指向单链表中结点
A,若删除单链表中结点
A,则需要改正指针的操作序列为(
)。
(A)q=p->next
;p->data=q->data
;p->next=q->next
;free(q)
;
(B)q=p->next
;q->data=p->data
;p->next=q->next
;free(q)
;
(C)q=p->next
;p->next=q->next
;free(q)
;
(D)q=p->next
;p->data=q->data
;free(q)
;
4.设有n个待排序的记录重点字,则在堆排序中需要(
)个协助记录单元。
(A)1
(B)n
(C)nlog2n
(D)n2
5.设一组初始重点字记录重点字为(20,15,14,18,21,36,40,10),则以20为基准记录的一趟迅速排序结束后的结果为()。
(A)10,15,14,18,20,36,40,21
(B)10,15,14,18,20,40,36,21
(C)10,15,14,20,18,40,36,2l
(D)15,10,14,18,20,36,40,21
6.设二叉排序树中有
n个结点,则在二叉排序树的均匀均匀查找长度为(
)。
(A)O
(1)
2
(C)
2
(B)O(logn)
(D)O(n)
7.设无向图G中有n个极点e条边,则其对应的毗邻表中的表头结点和表结点的个数分别为(
)。
(A)n,e
(B)e,n
(C)2n,e
(D)n,2e
8.
设某强连通图中有
n个极点,则该强连通图中起码有(
)条边。
(A)n(n-1)
(B)n+1
(C)n
(D)n(n+1)
9.设有5000个待排序的记录重点字,假如需要用最快的方法选出此中最小的
10个记录重点字,则用
以下(
)方法能够达到此目的。
(A)迅速排序
(B)堆排序
(C)
合并排序
(D)
插入排序
10.
以下四种排序中(
)的空间复杂度最大。
(A)插入排序
(B)冒泡排序
(C)
堆排序
(D)
合并排序
二、填空殖
(48分,此中最后两小题各
6分)