电大数据结构(本)期末综合练习二
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据结构(本)期末综合练习二
一、单项选择题
1.从n个数中选取最大元素()。
A.基本操作是数据元素间的交换B.算法的时间复杂度是O(n)
C.算法的时间复杂度是O(n2) D.需要进行(n+1)次数据元素间的比较
2.线性表采用链式存储时,其地址()。
A.一定是不连续的B.必须是连续的
C.部分地址必须是连续的D.可以连续也可以不连续
3.设head为非空的单向循环链表头指针,p指向链表的尾结点,则满足逻辑表达式()的值为真。
A.p->next=NULL B.p->next= =head
C.p->next=head D.p= =NULL
4.带头结点的单向链表的头指针为head,该链表为空的判定条件是()的值为真。
A.head = = NULL B.head->next= =head
C.head = =head->next D.head->next= = NULL
5.设顺序存储的线性表长度为n,要删除第i个元素,按课本的算法,当i=()时,移动元素的次数为3
A.3 B.n/2 C.n-3 D.3
6.设顺序存储的线性表长度为n,对于插入操作,设插入位置是等概率的,则插入一个元素平均移动元素的次数为()。
A.n B.n/2 C.n-1 D.n-i+1
7.一个栈的进栈序列是a,b,c,d,则栈的不可能的出栈序列是()。
A.dcba B.bcad
C.cbad D.adbc
8.一个栈的进栈序列是5,6,7,8,则栈的不可能的出栈序列是()(进出栈操作可以交替进行)
A.7,6,8,5 B.5,8,6,7
C.7,6,5,8 D.8,7,6,5
9.设有一个带头结点的链队列,队列中每个结点由一个数据域data和指针域next组成,front和rear分别为链队列的头指针和尾指针,要执行出队操作,用x保存出队元素的值,p为指向结点类型的指针,可执行如下操作:p=front->next;x=p->data; 然后指行()。
A.front=p->next; B.front->next =p;
C.front=p; D.front->next=p->next;
10.栈和队列的相同点是()。
A.都是后进先出B.都是后进后出
C.逻辑结构与线性表不同
D.逻辑结构与线性表相同,都是操作规则受到限制的线性表
11.在C语言中,存储字符串“ABCD”需要占用()字节。
A.4 B.2 C.5 D.3
12.在C语言中,利用数组a存放字符串“Hello”,以下语句中正确的是()。
A.char a[10]= “Hello”; B.char a[10]; a=“Hello”;
C.char a[10]= …Hello‟; D.char a[10]={…H‟,‟e‟,‟l‟,‟l‟,‟o‟};
13.设有一个10阶的对称矩阵A,采用压缩存储方式将其下三角部分以行序为主序存储到一维数组b中。(矩阵A的第一个元素为a1,1,数组b的下标从1开始),则矩阵
元素a5,3对应一维数组b的数组元素是()。
A.b[18] B.b[8] C.b[13] D.b[10] 14.设有一个15阶的对称矩阵A,采用压缩存储方式将其下三角部分以行序为主序存储到一维数组b中。(矩阵A的第一个元素为a1,1,数组b的下标从1开始),则数组元素b[13]对应A的矩阵元素是()。
A.a5,3B.a6,4C.a7,2D.a6,8 15.深度为5的完全二叉树共有20个结点,则第5层上有()个结点(根所在结点为第一层)。
A.3 B.8 C.5 D.6
16.一棵完全二叉树共有30个结点,则该树一共有()层(根结点所在层为第一层)。
A.6 B.4 C.3 D.5
17.已知一个图的所有顶点的度数之和为m,且m是以下4中情况之一,则m只可能是()。
A.9 B.7 C.15 D.8
18.以下说法正确的是()。
A.连通图G的生成树中不一定包含G的所有顶点
B.连通图G的生成树中一定要包含G的所有边
C.连通图G一定存在生成树
D.连通图G的生成树一定是唯一的
19.线性表只要以()方式存储就能进行折半查找。
A.链接B.顺序C.关键字有序的顺序D.二叉树20.对二叉排序树进行()遍历,遍历所得到的序列是有序序列。
A.按层次B.前序C.中序D.后序21.对n个元素进行冒泡排序若某趟冒泡中只进行了()次元素间的交换,则表明序列已经排好序。
A.1 B.2 C.0 D.n-1 22.以下排序算法中,在一趟排序过程中,除了其它相关操作外,只进行一次元素间的交换的算法是()。
A.冒泡B.直接选择C.直接插入D.折半插入23.在对一组元素(64,48,106,33,25,82,70,55,93)进行直接插入排序时,当进行到要把第7个元素70插入到已经排好序的子表时,为找到插入位置,需进行
()次元素间的比较(指由小到大排序)。
A.6 B.2 C.3 D.4 24.对长度为n的线性表进行顺序查找,在等概率情况下,平均查找长度为()。
A.n B.(n+1)/2 C.2n D.n-1 25.如图,若从顶点a出发按广度优先搜索法进行遍历,则可能得到的顶点序列为()。
A.acebdgf Array B.acfedgb
C.abecdgf
D.abecfdg
26.如图若从顶点a 出发按深度优先搜索法进行遍历,则可能得到的顶点序列为( )。
A .acfgedb
B .aedcbgf
C .acfebdg
D .aecbdgf
27.一棵哈夫曼树有10个非叶子结点(非终端结点),该树总共有( )个结点。 A .21 B .20 C .22 D .19 28.一棵哈夫曼树有12个叶子结点(终端结点),该树总共有( )个结点。 A .21 B .22 C .23 D .24 29.队列的插入操作在( )进行。
A .队头
B .队尾
C .队头或队尾
D .在任意指定位置
30.队列的删除操作在( )进行。
A .队尾
B .队头
C .队头或队尾
D .在任意指定位置
二、填空题
1.通常可以把某城市中各公交站点间的线路图抽象成______ __结构。 2.结构中的元素之间存在多对多的关系称为______ __结构。
3.要在一个单向链表中删除p 所指向的结点,已知q 指向p 所指结点的直接前驱结点,若链表中结点的指针域为next ,则可执行____ _ ___。
4.设有一个单向循环链表,结点的指针域为next ,头指针为head ,指针p 指向表中某结点,若逻辑表达式________的结果为真,则p 所指结点为尾结点。
5.设有一个链栈,栈顶指针为hs ,现有一个s 所指向的结点要入栈,则可执行操作 _______ _ 和hs=s ;
6.设有一个链栈,栈顶指针为hs ,现有一个s 所指向的结点要入栈,则可执行操作s-> next=hs; _______ _。
7.在一个不带头结点的非空链队中,f 和r 分别为队头和队尾指针,队结点的数据域为data ,指针域为next ,若要进行出队操作,并用变量x 存放出队元素的数据值,则相关操作为_____ ___; ______ _ _。
8.在一个链队中,f 和r 分别为队头和队尾指针,队结点的指针域为next ,s 指向一个要入队的结点,则入队操作为______ __;_______ _;
9.顺序存储字符串“ABCD ”需要占用________个字节。