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

东南大学数据结构试卷

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

自 觉 遵 守 考 场 纪 律 姓名 如 考 试 作 弊 此 答 卷 无 效号学

课程名称 数据结构

考试学期 08-09-3

得分

适用专业

吴健雄学院电类

考试形式

半开卷

考试时间长度 120分钟

一、选择题(每题1分,共5分)

1.下面有关链栈的描述,对常规情况正确的是 ( )

A.在链头插入,链尾删除。 B.在链尾插入,链头删除。 C.在链尾插入,链尾删除。 D.在链头插入,链头删除。

2.对线性表进行对半搜索时,要求线性表必须( )

线 A.以数组方式存储 B.以数组方式存储并按关键码排序 C.以链表方式存储 D.以链表方式存储并按关键码排序

3.对包含n个元素的散列表进行搜索,平均搜索长度为( )

A.O(log2n) B.O(n) C.不直接依赖于n D.三者均不是

封4.在同一个有向图中,所有结点的入度和与出度和之比为( ) A.1 B.2 C.1/2 D.都不对

5.在具有n个顶点的无向图中,要连通全部顶点至少需要( )条边。 A.n B.n+1 C.n-1 D.n/2

密二、判断题(每题1分,共5分)

1.链式存储的线性表所有存储单元的地址可连续可不连续。 ( ) 2.存储有向图的邻接矩阵是对称的,所以可以仅存矩阵上三角部分。 ( ) 3.在采用闭散列法解决冲突时,不要立刻做物理删除,否则搜索时会出错。 ( ) 4.二叉树中序遍历结果序列的最后一个结点必是前序遍历的最后一个结点。 ( ) 5.堆排序的时间复杂度是O(n log2 n),但需要额外存储空间。 ( )

三、填空题(每空1分,第1空、第2空为2分,共11分) 1.中缀表达式“(a+b)*d+e/(f+a*d)+c)”所对应的后缀表达式为 (1)

2.后缀表达式“ab&&ef>!||”所对应的中缀表达式为(2)

3.高度为h的二叉树最多可以有多少结点(3)

4.若对一棵完全二叉树从0开始编号,并按此编号把它顺序存储到一维数组a中,则a[i]

元素的左孩子结点为(4) ,右孩子结点为(5) ,双亲结点为(6) 。

5.对用邻接矩阵表示的图进行任何一种遍历时,其时间复杂度为(7) 。

对用邻接表表示的图进行任何一种遍历时,其时间复杂度为(8) 。 6.折半插入排序的时间复杂度为(9) 。

四、简答简述题(每题8分,共24分)

1.设有一组关键码输入序列{55,31,12,37,46,73,63,02,07},从空树开始构造

平衡二叉搜索树,画出每加入一个新结点时的二叉树形态,需标出平衡因子。包括发生不平衡时,旋转的各步的二叉树形态,并标注旋转类型。

2.已知一棵二叉树的前序遍历的结果为ABECDFGHIJ,中序遍历的结果是EBCDAFHIGJ,试

画出这棵二叉树。请用图表示逐步形成二叉树的过程(也可以用文字)。

3.请用Kruskal算法,逐步画出下面有权无向图的最小生成树。必须每次添加一条边。

01028141111615542231225624182

五、综合算法题(每空分,共55分)

1.完善改进的归并排序算法。*this是一个待排序的表,而表L2是一个辅助的工作表,帮助完成排序的中间步骤,最终完成*this的排序。所谓改进指在把元素序列复制到辅助表中时,把第2个表的元素顺序逆转,这样两个待归并的表从两端开始处理,向中间归并。可以省去检查子表是否结束的判断。

template void Orderedlist::MergeSort(int left, int right){ Orderedlist L2;

improvedMergeSort(L2, left, right); n\

5z60b7rodq2p7v43zg0p6rgfk15sw100hbz
领取福利

微信扫码领取福利

微信扫码分享