2013年“数据结构与C程序设计”(代码991)试题
一、单项选择题(本题共20分,每小题各2分)
1.对于长度为n的线性表,建立其对应的单链表的时间复杂度为( )。
A.O(1); B.O(log2n); .O(n); D.O(n2)。
2.一般情况下,在一个双向链表中插入一个新的链结点,( )。
A.需要修改4个指针域内的指针; B.需要修改3个指针域内的指针;
C.需要修改2个指针域内的指针; D.只需要修改1个指针域内的指针。
3.假设用单个字母表示中缀表达式中的一个运算数(或称运算对象),并利用堆栈产生中缀表达式对应的后缀表达式。对于中缀表达式A+B*(C/D-E),当从左至右扫描到运算数E时,堆栈中的运算符依次是( )。(注:不包含表达式的分界符)
A.+*/-; B.+*(/-; C.+*-; .+*(-。
4.若某二叉排序树的前序遍历序列为50,20,40,30,80,60,70,则后序遍历序列为( )。
A.30,40,20,50,70,60,80; B.30,40,20,70,60,80,50;
C.70,60,80,50,30,40,20; D.70,60,80,30,40,20,50。
5.分别以6, 3, 8, 12, 5, 7对应叶结点的权值构造的哈夫曼 (Huffman) 树的深度为( )。
A.6; B.5; C.4; D.3。
6.下列关于图的叙述中,错误的是( )。
A.根据图的定义,图中至少有一个顶点;
B.根据图的定义,图中至少有一个顶点和一条边(弧);
C.具有n个顶点的无向图最多有n(n-1)/2条边;
D.具有n个顶点的有向图最多有n(n-1)条边(弧)。
7.若在有向图G的拓扑序列中,顶点vi在顶点vj之前,则下列4种情形中不可能出现的是( )。
A.G中有弧<vi,vj>;
B.G中没有弧<vi,vj>;
C.G中有一条从顶点vi到顶点vj的路径;
D.G中有一条从顶点vj到顶点vi的路径。
8.下列关于查找操作的叙述中,错误的是( )。
A.在顺序表中查找元素可以采用顺序查找法,也可以采用折半查找法;
B.在链表中查找结点只能采用顺序查找法,不能采用折半查找法;
C.一般情况下,顺序查找法不如折半查找法的时间效率高;
D.折半查找的过程可以用一棵称之为“判定树”的二叉树来描述。
9.在一棵m阶B-树中,除根结点之外的任何分支结点包含关键字的个数至少是( )。
A.m/2-1; B.m/2; C.m/2-1; D.m/2。
10.若对序列(49, 38, 65, 97, 76, 13, 27, 49‟)进行快速排序,则第一趟排序结束(即确定了第1个分界元素的最终位置)时,序列的状态是( )。
A.(13, 27, 49‟, 38, 49, 76, 97, 65);B.(13, 38, 27, 49‟, 49, 76, 97, 65);
C.(13, 38, 49‟, 27, 49, 97, 76, 65);D.(13, 38, 49‟, 27, 49, 76, 97, 65)。
二、填空题(本题共20分,每小题各2分)
1.非空线性表在采( )存储结构的情况下,删除表的一个数据元素平均需要移动表中近一半元素的位置。
2.将一个长度为n的单链表链接到一个长度为m的单链表后面,该算法的时间复杂度用大O符号表示为
( )。
3.若完全二叉树的叶结点的数目为k,且最下面一层的结点数大于1,则该完全二叉树的深度为( )。
4.若深度为8的完全二叉树的第7层有10个叶结点,则该二叉树的结点总数为( )。
5.在具有n个顶点的有向图中,每个顶点的度最大可以达到( )。
6.若对有向图进行拓扑排序,则能够得到拓扑序列的条件是( )。
7.已知长度为10的顺序表中数据元素按值从小到大排列。若在该表中进行折半查找,则平均查找长度(ASL)是( )。
8.若在一棵m阶B-树的某个结点中插入一个新的关键字值而引起结点产生分裂,则该结点中原有的关键字值的数目是( )。
9.有一种排序方法可能会出现这种情况:最后一趟排序开始之前,序列中所有的元素都不在其最终应该在的位置上,这种排序方法是( )。
10.若按照泡排序法的思想将序列(2, 12, 16, 5, 10)中元素按值从小到大进行排序,整个排序过程中所进行的元素之间的比较次数为( )。
三、综合题(本题共20分,每小题各5分)
1.一般情况下,当一个算法中需要建立多个堆栈时可以选用下列三种处理方案之一。问:这三种方案之间相比较各有什么优点和缺点?
(1)多个堆栈共享一个连续的存储空间;
(2)分别建立多个采用顺序存储结构的堆栈;
(3)分别建立多个采用链式存储结构的堆栈。
2.已知二叉树采用二叉链表存储结构,根结点指针为T,链结点类型定义为:
typedef struct node{
char data; /* 数据域 */
struct node *lchild, *rchild; /* 指向左、右子树的指针域 */
} *BTREE;
下面的算法的功能是输出二叉树中所有叶结点的数据信息。
请在算法的空白处(符号-----处)填入合适内容,使算法完整。
void FUNC(BTREE T)
{ if(T!=NULL){
if((-----)
printf(“%c”, T->data);
FUNC(-----);
FUNC(-----);
}
}
3.对给定AOE网(如题三3图所示),请完成
(1)分别求出各活动ai(i=1, 2, …, 14)的最早开始时间与最晚开始时间;(以表格形式给出结果)
(2)求出所有关键路径。(请以图形方式画出各关键路径)
(说明:由于题三3图在本网站内无法显示,可参见指定教材p280页8-16题)
4.已知要将给定的关键字值序列(42, 51, 16, 26, 50, 25, 37, 68, 64, 33, 18)进行散列存储,并且要求装填因子(也称负载因子)α≈0.61,
(1)请利用除留余数法构造出合适的散列函数;
(2)请画出利用该散列函数依次将序列中各关键字值插入到散列表以后表的状态。设散列表初始为空,并且采用线性探测再散列法处理散列冲突。
四、算法设计题(本题15分)
假设长度为n的顺序表A[1..n]中每个数据元素为一整数,请写出按照下列思想将表
中数据元素按值从小到大进行排序的算法:第1趟排序将最小值元素放在A[1]中,最大
值元素放在A[n]中;第2趟排序将次小值元素放在A[2]中,次大值元素放在A[n-1]中;……,依此下去,直至排序结束。
五、填空题(本题共20分,每小题各2分)
1.已知某等比数列的第一项a1为1,公比为3,下列程序的功能是输出该数列中小于1000的最大项an及其对应的n。
请在程序的空白处(符号-----处)填入合适内容,使程序完整。
main( )
{ int n=1, a=1, q=3;
while(1){
a=a*q;
n++;
if(a>=1000)
-----;
}
printf(“n=%d,a=%d\n”, n-1, -----);
}
2.下列递归函数FUNC2的功能是判断整型数组a[n]是否为递增数组,即判断数组的元素是否按值从小到大排列。若是一个递增数组,则函数返回true,否则,函数返回false。
请在函数的空白处(符号-----处)填入合适内容,使函数完整。
bool FUNC2(int a[ ], int n)
{ if(n==1)
return true;
if(n==2)
return -----;
return ----- && (a[n-1]>=a[n-2]);
}
3.下列程序的功能是主函数调用FUNC3函数求方阵a中两条对角线上元素之和。
请在程序的空白处(符号-----处)填入合适内容,使程序完整。
#define N 10
void FUNC3(int a[N][N], int *p, int *q)
{ int i;
*p=0;
*q=0;
for(i=0; i<N; i++){
*p=*p+(*-----);
*q=*q+(*-----);
}
}
main( )
{ int a[N][N], i, j, x, y;
for(i=0; i<N; i++)
for(j=0; j<N; j++)
scanf(“%d”, *(a+i)+j);
FUNC3(a, &x, &y); /* x,y中分别存放主对角线与副对角线上的元素之和 */
printf(“%d, %d\n”, x, y);
}
4.下列程序的功能是先通过键盘输入一正整数,然后调用一递归函数FUNC4,该函数将正整数转换为对应的数字字符组成的字符串显示在屏幕上。例如:若输入的正整数为583,则屏幕上显示的是字符串583。 请在程序的空白处(符号-----处)填入合适内容,使程序完整。
#include <stdio.h>
void FUNC4(int n)
{ int i;
i=n/10;
if(-----)
FUNC4(i);
putchar(-----);
}
main( )
{ int n;
printf(“请输入一正整数n:”);
scanf(“%d”, &n);
printf(“转换后的字符串是:”);
FUNC4(n);
}
5.下列程序的功能是将小写字母转换成对应的大写字母后的第2个字母,例如,将a转换成C,将b转换成D,其中,y转换成A,z转换成B。
请在程序的空白处(符号-----处)填入合适内容,使程序完整。
#include <stdio.h>
main( )
{ char ch;
while((ch=getchar( ))!=„\n‟)
if(ch>=„a‟ && ch<=„z‟){
-----;
if(ch>„Z‟ && ch<=„Z‟+2)
-----;
}
}
6.下列函数FUNC6的功能是删除字符串s中的所有空白字符,包括Tab字符、回车符以及换行符。 请在函数的空白处(符号-----处)填入合适内容,使函数完整。
#include <stdio.h>
#include <string.h>
#include <ctype.h>
FUNC6(char *s)
{ int i, t;
char c[80];
for(i=0,t=0; s[i]; i++)
if(!isspace(-----))
c[-----]=s[i];
c[t]=„\0‟;
strcpy(s, c);
}
7.下列程序的功能是判断输入的字符串是否是“回文”。(注:按顺序读与按逆序读都一样的字符串被称为“回文”,例如:abcdcba)。
请在程序的空白处(符号-----处)填入合适内容,使程序完整。
#include <stdio.h>
#include <string.h>
main( )
{ char ch[81], *p=ch, *q;
gets(p);
q=p+-----;
while(-----){
if(*p==*q){
p++; q--;
}
else
break;
}
if(p<q)
printf(“该字符串不是回文!\n”);
else
printf(“该字符串是回文!\n”);
}
8.下列程序的功能是:对于字符类型变量ch=108,保留中间两位,而将高、低3位清零。
请在程序的空白处(符号-----处)填入合适内容,使程序完整。
main( )
{ char ch;
ch=108;
ch=-----;
printf(“%d”, ch);
}
9.设file为存放了整型数据的二进制文件。下列程序的功能是从该文件中读入第3个数据输出到屏幕上。 请在程序的空白处(符号-----处)填入合适内容,使程序完整。
#include <stdio.h>
main( )
{ FILE *fp;
int number;
fp=fopen(“file”,“rb”);
fseek(fp, -----, SEEK_SET);
fread(-----, 1, fp);
printf(“%d”, number);
fclose(fp);
}
10.下列程序的功能是将一个磁盘中的二进制文件复制到另一个磁盘中。两个文件的文件名随命令行一起输入,输入时原有文件的文件名在前,新复制文件的文件名在后。
请在程序的空白处(符号-----处)填入合适内容,使程序完整。
#include <stdio.h>
main(int argc, char *argv[ ])
{ FILE *old, *new;
if(argc!=3){
printf(“You forgot to enter a filename!\n”);
exit(0);
}
if((old=fopen(-----)==NULL){
printf(“Cannot open infile!\n”);
exit(0);
}
if((new=fopen(-----)==NULL){
printf(“Cannot open outfile!\n”);
北京航空航天大学2013年"数据结构与C语言程序设计"(991)考研真题
本站小编 免费考研网/2015-12-07
相关话题/数据结构
北京航空航天大学2012年"数据结构与C语言程序设计"(991)考研真题
北京航空航天大学2012年硕士研究生入学考试试题 “数据结构与C语言程序设计”(科目代码:991) 一、填空题(本题共20分,每小题各2分) 1.从总体上说,“数据结构”课程主要研究三个方面的内容。 2.若对某线性表最常用的操作是在表中插入元素或者删除表中元素,则对于顺序存储结 构 和链式存储结 ...专业课考研资料 本站小编 免费考研网 2015-12-072010河北工业大学数据结构考研题及答案
2010年 一、 1. 所谓的双向链表,是指在每一个结点中,有两个指针域,其中一个指向该结点的直接后继结点,而另一个则指向 。 【答案】其直接前趋结点 2. 线性表的顺序存储结构是一种 【答案】随机 3. 若一棵根树的每个结点最多只有分,次序不能颠倒,则称此根树为 。 【答案】两个,左、右,二叉树 4. 满二叉树是指 ...专业课考研资料 本站小编 免费考研网 2015-12-06北京理工大学2015年硕士研究生入学考试数据结构889考研试题
北京理工大学2015年 硕士研究生入学考试数据结构889试题: 一、选择题(40分。20道,每道2分) 1. 算法的可选项是() A 确定性 B 有穷性C 输入D输出 2.下列不属于数组的特点是() A 不属于线性结构 B C D数据元素的类型可以不同 3.下列属于逻辑结构的是() A顺序表B哈希表C单链表D有序表 4.下列属于逻辑结构中 ...专业课考研资料 本站小编 免费考研网 2015-11-162015年南京邮电大学数据结构考研真题
2015年南京邮电大学数据结构考研初试题目 判断题(共15题*2分) 1.消除递归不一定需要使用栈,此说法()2.稀疏矩阵压缩存储后,必会失去随机存取功能( 3.完全二叉树中,若一个结点没有左孩子,则它必是叶结点( 4.连通分量是无向图的极大强连通子图() ) )))5.在9阶B-树中,除叶子以外的任意结点的分支数介于5和9之间(6. ...专业课考研资料 本站小编 免费考研网 2015-11-07北京航空航天大学软件学院2013年“数据结构与C程序设计”(代码991)试题
2013年数据结构与C程序设计(代码991)试题 一、单项选择题(本题共20分,每小题各2分) 1.对于长度为n的线性表,建立其对应的单链表的时间复杂度为( )。 A.O(1); B.O(log2n); .O(n); D.O(n2)。 2.一般情况下,在一个双向链表中插入一个新的链结点,( )。 A.需要修改4个指针域内的指针; B.需 ...专业课考研资料 本站小编 免费考研网 2015-10-22数据结构1800试题 每题都来自各大学校各年份考研真题整理
第一章 绪论 一、选择题 1. 算法的计算量的大小称为计算的( )。【北京邮电大学2000 二、3 (20/8 分)】 A.效率 B. 复杂性 C. 现实性 D. 难度 2. 算法的时间复杂度取决于( )【中科院计算所 1998 二、1 (2 分)】 A.问题的规模 B. 待处理数据的初态 C. A 和B 3.计算机算法指的是(1),它必须具备(2) 这三个特 ...专业课考研资料 本站小编 免费考研网 2015-10-22数据结构讲义 《数据结构》C语言版 严蔚敏,清华大学出版社
复习提示一、教材内容l 使用教材《数据结构》C语言版 严蔚敏,清华大学出版社。l 章节 去掉 第5、8、11、12章 去掉 **部分 去掉1.3,2.4,4.4二、复习提示1. 经典算法单链表:遍历、插入、删除循环队列:队列空、队列满的条件二叉树:递归遍历及应用有序表的二分法查找快速排序简单选择排序2. 绪论掌握几个重 ...专业课考研资料 本站小编 免费考研网 2015-10-142016年考研核心考点命题思路解密 数据结构
《2016年考研核心考点命题思路解密 数据结构》严格按照最新计算机考研408统考大纲的数据结构部分编写,涵盖大纲指定的所有考试内容。本书对统考大纲所涉及的知识点进行深入剖析和总结,并精心策划和部署每一个章节,对每一个章节的考点做了独家策划。 本书每一个考点中的命题,绝大部分来源于历年名校计算机考研真题和 ...计算机考研资料 本站小编 网络资源 2015-07-172015年华北电力大学大学数据结构考研真题
2015年华北电力大学大学数据结构考研真题 第一题选择,10道题20分,很简单,比王道上的题要简单的多把王道的题做了,选择基本没问题。 第二题填空题10空20分,也很简单,数据存储类型为〔〕〔〕,存储数据即要存储〈〉还要存储〈〉,循环队列是为了〈〉,给出一组数据和散列函数求与28是同义词的是〈〉,还有一空求叶子节 ...专业课考研资料 本站小编 网络资源 2015-07-132015年华北电力大学数据结构与操作系统考研真题
2015年华北电力大学数据结构与操作系统考研真题 第一题是4个简答,包括简述数据存储结构的特点等,主要是概念掌握和基础思路。选择题和填空题主要是课后题那种。程序设计要求设计一个算法查找出二叉链表中度为1的结点和叶子结点的个球。 操作系统部分主要是基础知识点,大题就是考察进程控制的部分。 ...专业课考研资料 本站小编 华北电力大学 2015-07-13