中山大学 2015 年918专业基础(数据结构)考研真题

                     

贡献者: xzllxls

   声明:“该内容来源于网络公开资料,不保证真实性,如有侵权请联系管理员”

1. 一、单项选择题(每小题 3 分,共 45 分)

   1. STL 中的优先队列是采用什么数据结构来实现的?
A.堆 B.队列 C.栈 D.图

   2.数据结构中,与所使用的计算机无关的是数据的()结构。
A.存储 B.物理 C.逻辑 D.物理和存储

   3.计算机算法指的是( )。
A.计算方法 B. 排序方法
C.调度方法 D. 解决问题的有限指令序列

   4.给定一个有 n 个元素的数组(n 为偶数)。如果要找出数组中的最大元素和最小元素,最少要进行( )次比较?
A.2n B.3n/22 C.2n2 D.4n/3

   5.给定一个包含 250 个整数的数组,该数组中的整数已按从小到大的顺序排好序。假设用二分查找从该数组中寻找某个给定的整数 y,最多只需要做( )次比较。
A.8 B.9 C.10 D.7

   6. T(n) 表示某个算法的时间复杂度。假设 T(n)=2T(n/2)+O(m),则 T(n) 为( )
A. O(log3n) B. O(n) C. O(nlog3n) D. O(n2)

   7.假设整数 n>0,下面的程序的时间复杂度是( ).

x=2;
while (x<n/3) x=2*x;
A. O(log2n) B. O(m) C. O(nlog2n) D.O(n)

   8.下列排序算法中,哪个是稳定的排序算法?
A.选择排序 B. 快速排序 C. 归并排序 D. 希尔排序

   9.假设小明用某-排序算法对整数序列(82, 45, 25, 15, 21)进行排序。以下为排序过程中序列状态的变化过程:
输入:82 45 25 15 21
第一步:45 82 25 15 21
第二步:25 45 82 15 21
第三步:15 25 45 82 21
......
请问小明用的是什么排序算法?
A.选择排序 B.归并排序 C.快速排序 D.插入排序

   10.以下的排序算法中,哪个算法在最坏情况下的时间复杂度是 0(n3)?
A.堆排序 B. 快速排序 C. 归并排序 D. 基数排序

   11.给定一个算术表达式 XX 的中缀形式是 AB+CDE,且 X 的前缀形式是 +ABCDE.那么,x 的后缀形式是什么?
A. ACDEB+ B. ABCD+E C. CDEAB+ D. ABCDE+

   12.给定一棵空的 AVL 树,依次把 13, 24, 37, 90, 53 逐一插入该树,在此过程中要保持该树为 AVL 树(假设左子树的元素要小于右子树) .则最终得到的 AVL 树的高度是( ), 树根是( ).
A.3,37 B.3, 24 C.4, 37 D.3, 53

   13.下面哪个函数随着 n 增大而增长得最快?( ).
A.100n2log2n
B.n(log2n)5
C.n2.1
D.n2+1000nlog2n

   14.一个有 n 个顶点的无向图最多有( )条无向边(假设该图无自环)。
A.n B. n(n1) C. n(n1)/2 D.2n

   15.一棵高度为 k 的二又树最多有( )个节点
A.2k+11 B.2k1
C.2k+11 D.2k+1.

2. 二、简答题(共 55 分)

   1. (11 分)给定一个整数数组{4,6,3,2,1,5,7}.假设用选择排序算法对数组中的整数进行从小到大排序。请写出每次迭代后数组中的状态( 即每次迭代后,数组中的 7 个整数是如何排序的)

   2. (11 分)从空的二叉树开始,根据字典顺序,严格按照二叉排序树(或称二叉搜索树)的插入算法,依次插入 e,b, d, f, a, g, C。请画出构造二叉排序树的每一步骤。

   3. (10 分)假定一个堆为(56,38,42,30,25,40,35,20),则依次从中删除两个元素后得到的堆是什么?要求画出过程。

   4.给定一个空的哈希表,依次把键 12, 34, 55, 54, 13, 21, 19, 70 插入到哈希表中。假没采用的哈希函数是 b(k)=k mod 11,采用线性探查(linear probing)来解决冲突
(1)当上述键值全部插入后,请画出哈希表的状态(6 分)
(2)假如每个键值被查找的概率均等,请计算出平均查找长度(average search length) (6 分)

表1:第二 4 题表
下标 0 1 2 3 4 5 6 7 8 9 10

   5. 给定图 G 如下

图
图 1:第二 5 题图

   (1)请找出并画出图 G 的一棵最小代价生成树. (5 分)
(2)请画出图 G 对应的邻接矩阵. (6 分)

3. 三、编程题(共 50 分)

   1. (10 分)以下是一个(不完整的)直接插入排序算法的代码,请根据注释的提示把缺少的代码补充完整。

void insertion_sort(int entrylI, int count)
{
    int first. unsorted;  // position of first unsorted entry
    int position;         // searches sorted part of list
    int current;          // holds the entry temporarily removed from list
    for(first_unsorted = 1; first_unsorted < count; first_unsorted++)
    {
        if(entry[first_unsorted] < entry[first_unsorted-1])
        {
            // please complete the code here
        }
    }
}

   2. (15 分)逆转链表:写一算法逆置带头结点的单链表 L,要求逆置后的单链表利用 L 中的原结点,不可以重新申请结点空间。链表结点的声明如下:

template <class Entry>
struct Node{
    Entry data;
    Node<Entry> * next;
};
请实现下面的函数:
void reverse(Node<Entry>* L)

   3. (25 分)写一个算法,逐层遍历一棵二叉树(从上到下,从左到右)。以下是二叉树及二叉树中的节点的声明:

template <class Entry>
class Binary_tree {
public:
    Binary_tree();
    void Layer_order(vold(*visit)(Binary_node<Entry> &));
protected:
    Binary_node<Entry> * root;
};
template <class Entry>
struct Binary_node{
    Entry data;
    Binary_node<Entry> * left;
    Binary_node<Entry> * right;
    Binary_node();
    Binary_node(const Entry &x);
};
请实现下面的函数:
void Layer.order(void(*visit)(Entry &)).

                     

© 小时科技 保留一切权利