版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、完美 WORD格式编辑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)
2、,当从左至右扫描到运算数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
3、. 4; D. 3。6. 下列关于图的叙述中,错误的是()。A. 根据图的定义,图中至少有一个顶点;B. 根据图的定义,图中至少有一个顶点和一条边 (弧);C. 具有n个顶点的无向图最多有n(n-1)/2 条边;D. 具有n个顶点的有向图最多有n(n-1)条边(弧)。7. 若在有向图G的拓扑序列中,顶点 vi在顶点vj之前,则下列4种情形中不可能出现的是()。A. G中有弧 ;B. G中没有弧 ;C. G中有一条从顶点vi到顶点vj的路径;D. G中有一条从顶点vj到顶点vi的路径。&下列关于查找操作的叙述中,错误的是()。A. 在顺序表中查找元素可以采用顺序查找法,也可以采用折半查找法;B.
4、 在链表中查找结点只能采用顺序查找法,不能采用折半查找法;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,
5、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个叶结点,则该二叉树的结点总数
6、为()。5在具有n个顶点的有向图中,每个顶点的度最大可以达到()。6若对有向图进行拓扑排序,则能够得到拓扑序列的条件是()。7.已知长度为10的顺序表中数据元素按值从小到大排列。若在该表中进行折半查找,则平均查找长度(ASL) 是()。&若在一棵m阶B-树的某个结点中插入一个新的关键字值而引起结点产生分裂,则该结点中原有的关键 字值的数目是()。9.有一种排序方法可能会岀现这种情况:最后一趟排序开始之前,序列中所有的元素都不在其最终应该在的位置上,这种排序方法是()。10若按照泡排序法的思想将序列 (2, 12, 16, 5, 10)中元素按值从小到大进行排序,整个排序过程中所进行的元素之间的
7、比较次数为()。三、综合题(本题共20分,每小题各5分)1. 一般情况下,当一个算法中需要建立多个堆栈时可以选用下列三种处理方案之一。问:这三种方案之间 相比较各有什么优点和缺点?(1 )多个堆栈共享一个连续的存储空间;(2) 分别建立多个采用顺序存储结构的堆栈;(3) 分别建立多个采用链式存储结构的堆栈。T,链结点类型定义为:/* 数据域*/*指向左、右子树的指针域 */2已知二叉树采用二叉链表存储结构,根结点指针为typedef struct nodechar data;struct node *lchild, *rchild; *BTREE ;下面的算法的功能是输岀二叉树中所有叶结点的数
8、据信息。请在算法的空白处(符号-处)填入合适内容,使算法完整。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)进行
9、散列存储,并且要求装填因子(也称负载因子)a-0.61,(1 )请利用除留余数法构造出合适的散列函数;(2)请画岀利用该散列函数依次将序列中各关键字值插入到散列表以后表的状态。设散列表初始为空,并且采用线性探测再散列法处理散列冲突。四、算法设计题(本题 15分)假设长度为n的顺序表A1.n中每个数据元素为一整数,请写岀按照下列思想将表中数据元素按值从小到大进行排序的算法:第1趟排序将最小值元素放在A1中,最大值元素放在An中;第2趟排序将次小值元素放在A2中,次大值元素放在 An-1中;,依此下去,直至排序结束。五、填空题(本题共20分,每小题各2分)1. 已知某等比数列的第一项al为1,公比
10、为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的功能是判断整型数组an是否为递增数组,即判断数组的元素是否按值从小到大排列。若是一个递增数组,则函数返回true,否则,函数返回false。请在函数的空白处(符号-处)填入合适内容,使函数完整。bool FUNC2(int a , int n)if(n=1)return true;
11、if(n=2)return ;return & (an-1=an-2);3下列程序的功能是主函数调用FUNC3函数求方阵a中两条对角线上元素之和。请在程序的空白处(符号-处)填入合适内容,使程序完整。#define N 10void FUNC3(int aNN, int *p, int *q)int i;*p=0;*q=0;for(i=0; iN; i+)*p=*p+(*-);*q=*q+(*-);main()int aNN, i, j, x, y;for(i=0; iN; i+) for(j=0; jN; j+) scanf( “d , *(a+i)+j);FUNC3(a, &x, &y);
12、 /* x , y中分别存放主对角线与副对角线上的元素之和*/printf(“d, %d n” , x, y);4下列程序的功能是先通过键盘输入一正整数,然后调用一递归函数FUNC4该函数将正整数转换为对应的数字字符组成的字符串显示在屏幕上。例如:若输入的正整数为583,则屏幕上显示的是字符串 583。请在程序的空白处(符号-处)填入合适内容,使程序完整。#include void FUNC4(int n)int i;i=n/10;if(-)FUNC4(i);putchar();main()int n;printf(请输入一正整数 n:” scanf( “d , &n);printf(转换后的
13、字符串是:”FUNC4(n);2个字母,例如,将a转换成C,将b转换5下列程序的功能是将小写字母转换成对应的大写字母后的第成D,其中,y转换成A, z转换成B请在程序的空白处(符号-处)填入合适内容,使程序完整#include main()char ch;while(ch=getchar( )!= n)if(ch=a & ch Z & ch= Z +2)6.下列函数FUNC6勺功能是删除字符串s中的所有空白字符,包括Tab字符、回车符以及换行符请在函数的空白处(符号-处)填入合适内容,使函数完整。#include #include #include FUNC6(char *s)int i, t
14、;char c80;for(i=0,t=0; si; i+)if(!isspace()c=si;ct= 0strcpy(s, c);7下列程序的功能是判断输入的字符串是否是“回文”。(注:按顺序读与按逆序读都一样的字符串被称为“回文,例如:abcdcba)。请在程序的空白处(符号-处)填入合适内容,使程序完整。#include #include main()char ch81, *p=ch, *q;gets(p);q=p+;while()if(*p=*q)p+; q-;elsebreak;if(pq)printf(“该字符串不是回文!n”elseprintf(“该字符串是回文!n”);&下列程
15、序的功能是:对于字符类型变量ch=108,保留中间两位,而将高、低3位清零。请在程序的空白处(符号-处)填入合适内容,使程序完整。main()char ch;ch=108;ch=; printf( “d , ch);9.设file为存放了整型数据的二进制文件。下列程序的功能是从该文件中读入第3个数据输岀到屏幕上请在程序的空白处(符号-处)填入合适内容,使程序完整。#include main()FILE *fp;int number;fp=fopen( “file ” , “rb ” );fseek(fp, -, SEEK_SET);fread(,1, fp);printf(“d , numbe
16、r);fclose(fp);10 .下列程序的功能是将一个磁盘中的二进制文件复制到另一个磁盘中。两个文件的文件名随命令行一起 输入,输入时原有文件的文件名在前,新复制文件的文件名在后。请在程序的空白处(符号-处)填入合适内容,使程序完整。#include 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(n
17、ew=fopen()=NULL)printf(“Cannot open outfin” );exit(0); while(!feof(old) fputc(fgetc(old), new);fclose(old); fclose(new);六、简答题(本题共20分,每小题各5分)1在C语言中,函数调用时数据的传递通常有哪几种方式?2在C语言中,指针可以做哪些运算?3.共用体(union)具有哪些基本特征?4使用文件的基本操作步骤是怎样的?七、程序设计题(本题 15分)请编写一程序,该程序的功能是找出并且删除一维整型数组a100中的最小值元素。要求:1 数组各元素通过键盘输入获得初值;2. 所有
18、对数组元素的引用必须通过指针完成。八、程序设计题(本题 20分)请仅编写出一 C语言函数char *maxword(char *s, char *t),该函数的功能是求出字符串s与字符串t的最长公共单词(这里,假设两个字符串均由英文字母和空格字符组成);若找到这样的公共单词,函数返回该单词,否则,函数返回NULL。例如:若 s= “This is C programming text ”,t= “This is a text for C programming ”,则函数返回“programmi ng”。要求:1.函数中不得设置保存单词的存储空间;2. 给岀函数之前请用文字简要叙述函数的基本思
19、想。2013年“数据结构与C程序设计”(代码991)试题参考答案一、单项选择题1. C2. A3. D4 . B5. C6. B7. D8. A9. C10. D、填空题1顺序2.O(m)3 .log2k+14.2355.2 (n-1)6.该有向图中不存在回路7. 2.98. m-19.插入排序法10. 9三、综合题i 答:(1)多个堆栈共享一个连续的存储空间,可以充分利用存储空间,只有在整个存储空间都用完时才 能产生溢出,其缺点是当一个堆栈溢出时需要向左、右栈查询有无空闲单元。若有,则需要移动相应元素 和修改相关的栈底和栈顶指针的位置。当各个堆栈接近溢岀时,查询空闲单元、移动元素和修改栈底栈
20、顶 指针位置的操作频繁,计算复杂,并且耗费时间。(2) 每个堆栈仅用一个顺序存储空间时,操作简便。但难以确定初始分配存储空间的大小,空间分配少了,容易产生溢岀,空间分配多了,容易造成空间浪费;并且各个堆栈不能共享空间。(3) 一般情况下,分别建立多个链接堆栈不考虑堆栈的溢岀(仅受用户内存空间限制),缺点是堆栈中各 元素要通过指针链接,比顺序存储结构多占用存储空间。2. (T-lchild=NULL & T-rchild=NULL)T-lchildT-rchild3. (由于图表显示限制,此题答案见指定教材(数据结构教程 第二版(2012年4月第7次印刷)第418 页8-16题)4.(1).根据
21、a =散列表中存入的元素数/散列表的长度,得到表的长度为18,因此,合适的散列函数应该为H(k)=k MOD 17。(2).(由于图表显示限制,此题答案见指定教材(数据结构教程 第二版(2012年4月第7次印刷)第428 页 9-15 题)四、算法设计题SORT(int A , int n)int ,i, j, min, max, temp;i=1;while(i=n/2)min=i;max=i;for(j=i+1;jAmax)max=j;/*确定某趟排序的最小值元素和最大值元素*/if(min!=i)temp=Amin; Amin=Ai; Ai=temp;/* 交换Amin与Ai的位置*/i
22、f(max!=n-i+1)if(max=i)temp=Amin; Amin=An-i+1; An-i+1=temp; /* 交换 Amin与 An-i+1的位置 */elsetemp=Amax; Amax=An-i+1; An-i+1=temp;/* 交换Amax与An-i+1的位置*/i+;五、填空题1. break a/q2.an-1=an-2FUNC2(a, n-1)(*(a+i)+N-i-1)4. i!=0 n%10+ O5. ch-=30 ch-=266 .*(s+i)t+7 . strlen(p)-1 pq8 . ch &24(*(a+i)+i)9 .4学习指导参考资料&numbe
23、r10. argv1,“rb” argv2,“wb六、简答题1答:通常有下列三种方式:(1) 参数传递方式:函数调用时根据实参传递给形参内容的不同又分为值传递与地址传递两种。通过return语句传递数据:被调用函数可以通过 return语句将函数值传递给调用函数。(3)利用全局变量传递数据。2答:指针可以进行下列三种运算:(1) 指针加/减一个整数。表示以当前指针所指单元的地址为起点的后或前整数个数据的地址。(2) 指针减指针。表示两个地址之间的数据个数。(指针加指针为非法运算)(3) 比较。表示同类型的两个指针所指对象在地址位置上的关系。3答:共用体具有以下三个特征:(1) 共用体变量的成员
24、共用一块存储空间,共用体变量所占用的字节数等于最长成员所占用的字节数;(2) 共用体不能在定义时进行初始化;(3) 共用体中的成员每次只能有一个起作用,当存入新成员时,原来的成员失效,其值被覆盖。4答:使用文件的基本操作一般有下列五个步骤:(1) 在程序中包含头文件 stdio.h(2) 定义文件指针。例如:FILE *fp;(3) 打开文件,使文件指针与磁盘中的实际存储的数据文件建立关联。例如:fp=fopen( “test.txt ” ,“r” ); 对文件进行读写操作。例如:fread(f, 4, 2, fp);(5)文件使用完毕后,关闭文件。例如: fclose(fp);七、程序设计题#include main()int a100, i, *p, k=0;p=a;for(i=0; i100; i+)scanf( “d , p+i); /*对数组进行数据输入*/for(i=1; i*(p+i)k=i;for(i=k; i99; i+)/* 删除最
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业资源调配申请与审批标准化工具
- 团队协作会议记录模板及分析工具
- 低空经济「设备租赁」与共享经济协同发展2025年产业前景预测与分析报告
- 没有 网签合同
- 2025年服装店长考试试题及答案
- 保证合同 从合同
- 电商一件代发合同
- 英文 购销合同
- 2025年寨卡病毒考试试题及答案
- 2025企业雇佣合同
- 神经外科患者血压护理
- 化工企业生产过程异常工况安全处置准则培训
- 人教版六年级数学上册【全册教案】
- IATF16949体系推行计划(任务清晰版)
- 人教版(2024新版)七年级上册数学期中模拟试卷(第1章 有理数~第3章 代数式)(含答案)
- 借款房产抵押合同
- HG∕T 5166-2017 反渗透阻垢剂阻垢性能评价方法
- 网吧员工培训与管理制度样本
- DB21T 3970-2024 油松冻土坨营养杯苗造林技术规程
- 铁塔吊装专项施工方案
- 2024年长江产业投资集团有限公司招聘笔试参考题库附带答案详解
评论
0/150
提交评论