好文档 - 专业文书写作范文服务资料分享网站

数据结构试题及答案(10套)

天下 分享 时间: 加入收藏 我要投稿 点赞

{

stack a; initstack(a); int x; cin >>x;

while (x! = -1) { push (a, x ); cin >>x; }

while (!stackempty (a)) cout <

该算法的输出结果为:

__________________________________________________________. 2、阅读以下二叉树操作算法,指出该算法的功能。 Template void BinTree ::

unknown (BinTreeNode*t) {

BinTreeNode< Type> *p =t, *temp; if (p!=NULL) {

temp = p→leftchild;

p→leftchild = p→rightchild; p→rightchild = temp; unknown(p→leftchild); undnown(p→rightchild); } }

该算法的功能是:________________________________

五、 算法填空,在画有横线的地方填写合适的内容(10分)

对顺序存储的有序表进行二分查找的递归算法 。 int Binsch( ElemType A[ ],int low ,int high,KeyType K ) {

if (low <= high) {

int mid = 1

if ( K= = A[ mid ].key ) return mid;

else if ( K < A[mid].key) return 2 else

return 3 } else

return 4

六、 编写算法(10分)

编写算法,将一个结点类型为Lnode的单链表按逆序链接,即若原单链表中存储元素的次序为a1,……an-1,an,则逆序链接后变为, an,an-1,……a1。 Void contrary (Lnode * & HL)

数据结构试题(答案)

一、单选题(每小题2分,共8分) 1 2 3 题 号 C D 答 案 二、填空题(每空1分,共32分) 1: 集合、线性、树、图; 2: 数据描述、操作声名;

3: (38,56,25,60,42,74); 4: HL→next =NULL; HL=HL→next; 5: 前一个位置; n-1; 6: []; HS→data; 7: 5 31

8: 边结点、邻接点域、权域、链域; 9: 索引值域、开始位置域; 10: 10、3、3、B、I和J; 11: O(log2n)、O(nlog2n); 12: m 、 m - 1

三、运算题(每小题6分,共24分) 1、

划分次序 第一次 第二次 第三次 第四次 A 4 B 划分结果 [38 24 40] 46 [56 80 95 79] 24 [38 40] 46 [56 80 95 79] 24 38 40 46 [56 80 95 79] 24 38 40 46 56 [80 95 79] 第五次 第六次 24 38 40 46 56 79 [80 95] 24 38 40 46 56 79 80 95 2、 0 1 2 3 4 5 6 7 8 9 10 11 78 15 03 57 45 查找成功的平均查找长度:ASL SUCC=14/10=

3、此二叉树的后序遍历结果是:EDCBIHJGFA 4、

图 邻接矩阵表示时 邻接表表示时 深度优先序列 0,1,2,8,3,4,5,6,7,9 0,4,3,8,9,5,6,7,1,2 广度优先序列 0,1,4,2,7,3,8,6,5,9 0,4,1,3,7,2,8,6,9,5 20 31 23 36 12 四、阅读算法,回答问题(每小题8分,共16分) 1、 1、 该算法的输入结果是:34 91 30 45 63 78

2、 2、 该算法的功能是:交换二叉树的左右子树的递归算法。 五、算法填空,在画有横线的地方填写合适的内容(10分) 1、1是:(low + high)/2;

2是: Binsch(A,low,mid–1,K); 3是: Binsch(A,mid+1,high,K); 4是: -1;

六、编写算法(10分) 根据编程情况,酌情给分。 {

Lnode *P=HL; HL=NULL;

While (p!=null) {

Lnode*q=p; P=p→next; q→next=HL; HL=q; } }

第一部分 选择题(30分)

一、项选择题(本大题共15小题,每小题2分,共30分)在每小题列出的四个选项中只有一个选项是符合题目要求的,请将正确选项前的字母填在题后的括号内。

1.算法指的是( )

A.计算机程序 B.解决问题的计算方法

C.排序算法 D.解决问题的有限运算序列 2.线性表采用链式存储时,结点的存储地址( ) A.必须是不连续的 B.连续与否均可 C.必须是连续的

D.和头结点的存储地址相连续

3.将长度为n的单链表链接在长度为m的单链表之后的算法的时间复杂度为( )

A.O(1) B.O(n) C.O(m) D.O(m+n) 4.由两个栈共享一个向量空间的好处是:( ) A.减少存取时间,降低下溢发生的机率 B.节省存储空间,降低上溢发生的机率

C.减少存取时间,降低上溢发生的机率 D.节省存储空间,降低下溢发生的机率

5.设数组data[m]作为循环队列SQ的存储空间,front为队头指针,rear为队尾指针,则执行出队操作后其头指针front值为( )

A.front=front+1 B.front=(front+1)%(m-1) C.front=(front-1)%m D.front=(front+1)%m 6.如下陈述中正确的是( )

A.串是一种特殊的线性表 B.串的长度必须大于零 C.串中元素只能是字母 D.空串就是空白串

7.若目标串的长度为n,模式串的长度为[n/3],则执行模式匹配算法时,在最

n坏情况下的时间复杂度是( )

A.O(3) B.O(n) C.O(n2) D.O(n3) 8.一个非空广义表的表头( )

A.不可能是子表 B.只能是子表

C.只能是原子 D.可以是子表或原子 9.假设以带行表的三元组表表示稀疏矩阵,则和下列行表

0 2 3 3 5 ?0?806??0?7000??0?7??0?806??? 对应的稀疏矩阵是( ) B.??0000000??05A.?0????00400?7D.??0 052C.???0?0000???5040?? ?? ???5??? ?0000? ?0?8?8000003006?6?000???400?0??000?0??040??0 ?300??

10.在一棵度为3的树中,度为3的结点个数为2,度为2 的结点个数为1,则度为

0的结点个数为( )

A.4 B.5 C.6 D.7

11.在含n个顶点和e条边的无向图的邻接矩阵中,零元素的个数为( ) A.e B.2e C.n2-e D.n2-2e

12.假设一个有n个顶点和e条弧的有向图用邻接表表示,则删除与某个顶点vi

相关的所有弧的时间复杂度是( ) A.O(n) B.O(e) C.O(n+e) D.O(n*e)

13.用某种排序方法对关键字序列(25,84,21,47,15,27,68,35,20)进

行排序时,序列的变化情况如下: 20,15,21,25,47,27,68,35,84 15,20,21,25,35,27,47,68,84 15,20,21,25,27,35,47,68,84 则所采用的排序方法是( )

A.选择排序 B.希尔排序 C.归并排序 D.快速排序 14.适于对动态查找表进行高效率查找的组织结构是( )

A.有序表 B.分块有序表 C.三叉排序树 D.线性链表 15.不定长文件是指( )

A.文件的长度不固定 B.记录的长度不固定

C.字段的长度不固定 D.关键字项的长度不固定

第二部分 非选择题(共70分)

二、填空题(本大题共10小题,每小题2分,若有两个空格,每个空格1分,

共20分)不写解答过程,将正确的答案写在每小题的空格内。错填或不填均无分。

16.数据的逻辑结构是从逻辑关系上描述数据,它与数据的 无关,是独立于计算机的。

17.在一个带头结点的单循环链表中,p指向尾结点的直接前驱,则指向头结点的指针head可用p表示为head= 。 18.栈顶的位置是随着 操作而变化的。

19.在串S=“structure”中,以t为首字符的子串有 个。

20.假设一个9阶的上三角矩阵A按列优先顺序压缩存储在一维数组B中,其

中B[0]存储矩阵中第1个元素a1,1,则B[31]中存放的元素是 。 21.已知一棵完全二叉树中共有768结点,则该树中共有 个叶子结点。

9lrnr0zcba0fvqu4yw276b8ve00zsa00v4t
领取福利

微信扫码领取福利

微信扫码分享