《最新全国计算机等级考试二级C语言题库(全).doc》由会员分享,可在线阅读,更多相关《最新全国计算机等级考试二级C语言题库(全).doc(213页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、-_2016 年年 3 月份全国计算机等级考试二级月份全国计算机等级考试二级 C 语言语言 题库(全)题库(全)一、选择题在下列各题的 A) 、B) 、C) 、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应位置上,答在试卷上不得分。(1)为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为 A)PAD 图 B)N-S 图 C)结构图 D)数据流图(2)结构化程序设计主要强调的是 A)程序的规模 B)程序的效率 C)程序设计语言的先进性 D)程序易读性 (3)为了使模块尽可能独立,要求 A)模块的内聚程度要尽量高,且各模块间的耦合
2、程度要尽量强 B)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量弱 C)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量弱 D)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量强 (4)需求分析阶段的任务是确定 A)软件开发方法 B)软件开发工具 C)软件开发费用 D)软件系统功能(5)算法的有穷性是指 A)算法程序的运行时间是有限的 B)算法程序所处理的数据量是有限的 C)算法程序的长度是有限的 D)算法只能被有限的用户使用 (6)对长度为 n 的线性表排序,在最坏情况下,比较次数不是 n(n-1)/2 的排序方法是 A)快速排序 B)冒泡排序 C)直接插入排序 D)堆排序 (7)如
3、果进栈序列为 e1,e2,e3,e4,则可能的出栈序列是 A)e3,e1,e4,e2 B)e2,e4,e3,e1 C)e3,e4,e1,e2 D) 任意顺序 (8)将 E-R 图转换到关系模式时,实体与联系都可以表示成 -_A)属性 B)关系 C)键 D)域(9)有三个关系 R、S 和 T 如下:RB C D a 0 k1 b 1 n1 SB C D f 3 h2 a 0 k1 n 2 x1 TBCDa0k1由关系 R 和 S 通过运算得到关系 T,则所使用的运算为 A)并 B)自然连接 C)笛卡尔积 D)交(10)下列有关数据库的描述,正确的是 A)数据处理是将信息转化为数据的过程 B)数据
4、的物理独立性是指当数据的逻辑结构改变时,数据的存储结构不变 C)关系中的每一行称为元组,每一个列称为属性D)如果一个关系中的属性或属性组并非该关系的关键字,但它是另一个关系的关键字,则称其为本关系的外关键字 (11)以下叙述中正确的是 A)用 C 程序实现的算法必须要有输入和输出操作 B)用 C 程序实现的算法可以没有输出但必须要有输入 C)用 C 程序实现的算法可以没有输入但必须要有输出 -_D)用 C 程序实现的算法可以既没有输入也没有输出 (12)下列可用于 C 语言用户标识符的一组是 A)void, define, WORD B)a3_3,_123,Car C)For, -abc, I
5、F Case D)2a, DO, sizeof 标识符由数字、字母、下划线组成,开头不能为数字(13)以下选项中可作为 C 语言合法常量的是 A)-80 B)-080 C)-8e1.0 D)-80.0e e 后为整数(14)若有语句:char *line5;,以下叙述中正确的是 A) 定义 line 是一个数组,每个数组元素是一个基类型为 char 为指针变量 B) 定义 line 是一个指针变量,该变量可以指向一个长度为 5 的字符型数组 C) 定义 line 是一个指针数组,语句中的*号称为间址运算符 D) 定义 line 是一个指向字符型函数的指针 (15)以下定义语句中正确的是 A)i
6、nt a=b=0; B)char A=65+1,b=b; C)float a=1,*b=D)double a=00;b=1.1; (16)有以下程序段 char ch; int k; ch=a;k=12; printf(“%c,%d,“,ch,ch,k); printf(“k=%d n“,k);已知字符 a 的 ASCII 码值为 97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 B)输出项与格式描述符个数不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12 (17)有以下程序 main() int i,s=1; for (i=1;i
7、=2 c=a; if(c!=a) c=b; printf(“%d,%d,%dn“,a,b,c); 其输出结果是 A)程序段有语法错 B)3,5,3 C)3,5,5 D)3,5,7 (20)有以下程序 #include main() int x=1,y=0,a=0,b=0; switch(x) case 1: switch(y) case 0:a+; break; case 1:b+; break; case 2:a+; b+; break; case 3:a+; b+; printf(“a=%d,b=%dn“,a,b); -_程序的运行结果是 A)a=1,b=0 B)a=2,b=2 C)a=1
8、,b=1 D)a=2,b=1 (21)下列程序的输出结果是 #include “stdio.h“ main() int i,a=0,b=0; for(i=1;i0;j+=2)s=10*s+pij-0; printf(“%dn“,s); 该程序的输出结果是 A)69825 B)63825 C)6385 D)693825 (27)有定义语句:char s10;,若要从终端给 s 输入 5 个字符,错误的输入语句是 A)gets( B)scanf(“%s“,s+1); C)gets(s); D)scanf(“%s“,s1); -_(28)以下叙述中错误的是 A)在程序中凡是以“#“开始的语句行都是预
9、处理命令行 B)预处理命令行的最后不能以分号表示结束 C)#define MAX 是合法的宏定义命令行 D)C 程序对预处理命令行的处理是在程序执行的过程中进行的 (29)设有以下说明语句 typedef struct int n; char ch8; PER; 则下面叙述中正确的是 A)PER 是结构体变量名 B)PER 是结构体类型名 C)typedef struct 是结构体类型 D)struct 是结构体类型名 (30)以下叙述中错误的是 A)gets 函数用于从终端读入字符串 B)getchar 函数用于从磁盘文件读入字符 C)fputs 函数用于把字符串输出到文件 D)fwrite
10、 函数用于以二进制形式输出数据到文件 (31)以下能正确定义一维数组的选项是 A)int a5=0,1,2,3,4,5; B)char a=0,1,2,3,4,5,0; C)char a=A,B,C; D)int a5=“0123“; (32)有以下程序 #include main() char p=a, b, c,q10= a, b, c; printf(“%d%dn“,strlen(p),strlen(q); 以下叙述中正确的是 A) 在给 p 和 q 数组置初值时,系统会自动添加字符串结束符,故输出的长度都为 3 B) 由于 p 数组中没有字符串结束符,长度不能确定,但 q 数组中字符串
11、长度-_为 3 C) 由于 q 数组中没有字符串结束符,长度不能确定,但 p 数组中字符串长度为 3 D) 由于 p 和 q 数组中都没有字符串结束符,故长度都不能确定 (33)有以下程序 #include #include void fun(char *s,int n) char *t; int i,j; for(i=0;istrlen(sj) t=si;si:sj;sj=t; main() char *ss=“bcc“,“bbcc“,“xy“,“aaaacc“,“aabcc“; fun(ss,5); printf(“%s,%sn“,ss0,ss4); 程序的运行结果是 A)xy,aaaac
12、c B)aaaacc,xy C)bcc,aabcc D)aabcc,bcc (34)有以下程序 #include int f(int x) int y; if(x=0|x=1) return(3); y=x*x-f(x-2); return y; main() int z; -_z=f(3); printf(“%dn“,z); 程序的运行结果是 A)0 B)9 C)6 D)8 (35)下面程序段的运行结果是 char str=“ABC“,*p=str; printf(“%dn“,*(p+3); A)67 B)0 C)字符C的地址 D)字符C (36)若有以下定义: struct link in
13、t data; struct link *next; a,b,c,*p,*q; 且变量 a 和 b 之间已有如下图所示的链表结构: 指针 p 指向变量 a,q 指向变量 c。则能够把 c 插入到 a 和 b 之间并形成新的链表的语句组是: A)a.next=c; c.next=b; B)p.next=q; q.next=p.next; C)p-next= q-next=p-next; D)(*p).next=q; (*q).next= (37)对于下述程序,在方式串分别采用“wt“和“wb“运行时,两次生成的文件TEST 的长度分别是 #include void main() FILE *fp
14、=fopen(“TEST“,); fputc(A,fp);fputc(n,fp);fputc(B,fp);fputc(n,fp);fputc(C,fp); fclose(fp); -_A)7 字节、7 字节 B)7 字节、5 字节 C)5 字节、7 字节 D)5 字节、5 字节 (38)变量 a 中的数据用二进制表示的形式是 01011101,变量 b 中的数据用二进制表示的形式是 11110000。若要求将 a 的高 4 位取反,低 4 位不变,所要执行的运算是 A)ab B)a|b C)a break; printf(“%dn“,i+);(9)以下程序的定义语句中,x1的初值是 【9】 ,
15、程序运行后输出的内容是 【10】 。 -_#include main() int x=1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,*p4,i; for(i=0;i void swap(int *a, int *b) int *t; t=a; a=b; b=t; main() int i=3,j=5,*p= swap(p,q); printf(“%d %dN,*p,*q) (11)以下程序的输出结果是 【12】 。 main() char s=“ABCD“, *p; for(p=s+1; p=2选项 C)中,数组名后少了中括号;选项 D)中,整型数组不能赋予字符
16、串。(32)A 【解析】 在给 p 和 q 数组赋初值时,系统会自动添加字符串结束符,从题目中可以看出数组 p 和 q 都有 3 个字符,所以长度均为 3。(33)A 【解析】 函数 fun(char *s,int n)的功能是对字符串数组的元素按照字符串的长度从小到大排序。在主函数中执行 fun(ss,5)语句后,*ss=“xy“, “bcc“, “bbcc“, “aabcc“, “aaaacc“,ss0,ss4的输出结果为 xy,aaaacc。(34)C 【解析】 函数 int f(int x)是一个递归函数调用,当 x 的值等于 0 或 1 时,函数值等于 3,其他情况下 y=x2-f(
17、x-2),所以在主函数中执行语句 z=f(3)时,y=3*3-f(3-2)=9-f(1)=9-3=6。(35)B 【解析】 考查指向字符串的指针变量。在该题中,指针变量 p 指向的应该是该字符串中的首地址,p+3 指向的是字符串结束标志0的地址,因而*(p+3)的值为 0。(36)D 【解析】 本题考查链表的数据结构,必须利用指针变量才能实现,即一个结点中应包含一个指针变量,用它存放下一结点的地址。(37)B 【解析】 以“wt“方式写入的是字符文件,转义字符n被看作两个字符来处理。而“wb“方式写入的是二进制文件,转义字符n是一个字符。(38)A 【解析】 本题考查的是位运算的知识,对于任何
18、二进制数,和 1 进行异或运算会让其取反,而和 0 进行异或运算不会产生任何变化。(39)C 【解析】 本题主要考查的是用二维数组首地址和下标来引用二维数-_组元素的方法。通过分析可知,程序中的双重循环定义了一个如下的二维数组:0 1 22 3 44 5 6由于数组的下标是从 0 开始的,所以二维数组元素 aij表示的是二维数组 a 的第 i+1 行、第 j+1 列对应位置的元素。 (40)A 【解析】 函数的参数不仅可以是整型、实型、字符型等数据,还可以是指针型。它的作用是将一个变量的地址传递到另一个函数中。当数组名作参数时,如果形参数组中的各元素的值发生变化,实参数组元素的值也将随之发生变
19、化。二、选择题(1)【1】调试 【解析】 软件测试的目标是在精心控制的环境下执行程序,以发现程序中的错误,给出程序可靠性的鉴定;调试也称排错,它是一个与测试既有联系又有区别的概念。具体来说,测试的目的是暴露错误,评价程序的可靠性,而调试的目的是发现错误的位置,并改正错误。(2)【2】19 【解析】 在任意一棵二叉树中,度为 0 的结点(即叶子结点)总是比度为 2 的结点多一个。(3)【3】 上溢 【解析】 入队运算是指在循环队列的队尾加入一个新元素。这个运算有两个基本操作:首先将队尾指针进一(即 rear=rear+1),并当 rear=m+1时,置 rear=1;然后将新元素插入队尾指针指向
20、的位置。当循环队列非空(s=1)且队尾指针等于队头指针时,说明循环队列已满,不能进行入队运算,这种情况称为“上溢“。(4)【4】 关系 【解析】 在关系模型中,把数据看成一个二维表,每一个二维表称为一个关系。表中的每一列称为一个属性,相当于记录中的一个数据项,对属性的命名称为属性名;表中的一行称为一个元组,相当于记录值。(5)【5】 操作系统或 OS 【解析】 数据库管理系统是数据库的机构,它是一-_种系统软件,负责数据库中的数据组织、数据操纵、数据维护、控制及保护和数据服务。位于用户和操作系统之间。(6)【6】 a 【解析】 z的 ASCII 码值为 122,经过 c-25 运算后,得 97
21、,以字符形式输出是 a。(7)【7】 1,0 【解析】 与运算两边的语句必须同时为真时,结果才为真。当执行完 if(+a=A,若要从终端给 s 输入 5 个字符,错误的输入语句是 A)gets( B)scanf(“%s“,s+1); C)gets(s); D)scanf(“%s“,s1);(28)有以下程序 #include #define N 5 #define M N+1 #define f(x) (x*M) main() int i1,i2; i1=f(2); i2=f(1+1); printf(“%d %dn“,i1,i2); 程序的运行结果是 A)12 12 B)11 7 C)11
22、11 D)12 7(29)若有以下说明和定义 union dt -_ int a; char b; double c;data; 以下叙述中错误的是 A)data 的每个成员起始地址都相同 B)变量 data 所占内存字节数与成员 c 所占字节数相等 C)程序段:data.a=5;printf(“%fn“,data.c);输出结果为 5.000000 D)data 可以作为函数的实参 (30)有以下程序 #include main() FILE *fp;int k,n,a6=1,2,3,4,5,6; fp=fopen(“d2.dat“,“w“); fprintf(fp,“%d%d%dn“,a0
23、,a1,a2); fprintf(fp,“%d%d%dn“,a3,a4,a5); fclose(fp); fp=fopen(“d2.dat“,“r“); fscanf(fp,“%d%d“,printf(“%d%dn“,k,n);fclose(fp); 程序运行后的输出结果是 A)1 2 B)1 4 C)123 4 D)123 456(31)若已定义 int a=0,1,2,3,4,5,6,7,8,9, *p=a,i; 其中 则对 a 数组元素不正确的引用是 A)ap-a B)*( i=n1; j=n2; while(i #include #include int fun (char *str)
24、 int i,j=0; for(i=0;stri!= 0;i+)if(stri!= )strj+=stri; strj= 0; main() char str81; int n; printf(“Input a string : “); gets(str); puts(str); fun(str); printf(“%sn“,str); -_A)asdafaaz67 B)asd af aa z67 C)asd D)z67(34)有以下程序 int fun(int n) if(n=1)return 1; else return(n+fun(n-1); main() int x; scanf(“%
25、d“, x=fun(x);printf(“%dn“,x) 执行程序时,给变量 x 输入 10,程序的输出结果是 A)55 B)54 C)65 D)45(35)下面程序段中,输出*的个数是 char *s=“ta018bc“; for(;*s!=0;s+)printf(“*“); A)9 B)5 C)6 D)7 (36)C 语言结构体类型变量在程序运行期间 A)TC 环境在内存中仅仅开辟一个存放结构体变量地址的单元 B)所有的成员一直驻留在内存中 C)只有最开始的成员驻留在内存中 D)部分成员驻留在内存中(37)已知函数的调用形式为 fread(buf,size,count,fp),参数 buf
26、 的含义是 A)一个整型变量,代表要读入的数据项总数 B)一个文件指针,指向要读的文件 C)一个指针,指向要读入数据的存放地址 D)一个存储区,存放要读的数据项(38)设有以下语句 char x=3,y=6,z; z=xy #define N 80 int fun(int a, int n) int i,j=1; for(i=1;i main() int x=1,y=0,a=0,b=0; switch(x) case 1: switch(y) case 0:a+; break; case 1: b+; break; case 2:a+; b+; break; case 3:a+; b+; pr
27、intf(“a=%d,b=%dn“,a,b); (10)以下程序的输出结果是 【11】 。 fun (int x,int y,int z) z =x*x+y*y; main () int a=31; fun (6,3,a) printf (“%d“, a) (11)函数 my_cmp( )的功能是比较字符串 s 和 t 的大小,当 s 等于 t 时返回0,否则返回 s 和 t 的第一个不同字符的 ASCII 码差值,即 st 时返回正值,s main() FILE *fp; char ch; -_fp=fopen( 【15】 ); ch=fgetc(fp); while(!feof(fp) p
28、utchar(ch); ch=fgetc(fp); putchar(n);fclose(fp);一、选择题(1)C 【解析】 程序流程图是人们对解决问题的方法、思路或算法的一种图形方式的描述。其中,图框表示各种操作的类型,图框中的文字和符号表示操作的内容;流程线表示操作的先后次序。带箭头的线段在数据流程图中表示数据流;带箭头的线段在程序流程图中表示控制流。题中给出的选项中,在图元之间用带有箭头的线段表示图元关系。在模块之间用带有箭头的线段表示调用关系。(2)C 【解析】 软件设计遵循软件工程的基本目标和原则,建立了适用于在软件设计中应该遵循的基本原理和与软件设计有关的概念,它们具有抽象、模块化
29、、信息隐蔽和数据独立性。自底向上是集成测试中增量测试的一种。(3)C 【解析】 模块之间的耦合程度反映了模块的独立性,也反映了系统分解后的复杂程度。按照耦合程度从强到弱分别是:内容耦合、公共耦合、外部耦合、控制耦合、标记耦合、数据耦合和非直接耦合,没有异构耦合这种方式。(4)D 【解析】 软件需求规格说明书(SRS,Software Requirement Specification)是需求分析阶段的最后成果,是软件开发中的重要文档之一。它具有以下几个方面的作用: 便于用户、开发人员进行理解和交流; 反映出用户问题的结构,可以作为软件开发工作的基础和依据; 作为确认测试和验收的依据。(5)C
30、【解析】 算法的复杂度主要包括算法的时间复杂度和空间复杂度。所谓算法的时间复杂度是指执行算法所需要的计算工作量,即算法执行过程中所需要的基本运算的次数;算法的空间复杂度一般是指执行这个算法所需要的内存空间。(6)B 【解析】 堆排序的比较次数为 nlog2n;直接插入排序的比较次数为 n(n-1)/2;快速排序的比较次数为 nlog2n。当数据表 A 中每个元素-_(7)B 【解析】 栈操作原则上“后进先出“,栈底至栈顶依次存放元素A、B、C、D,则表明这 4 个元素中 D 是最后进栈,B、C 处于中间,A 最早进栈,所以出栈时一定是先出 D,再出 C,最后出 A。(8)A 【解析】 数据库设
31、计包括数据库概念设计和数据库逻辑设计两个方面的内容。(9)A 【解析】 关系表中,每一行称为一个元组,对应表中的一条记录;每一列称为一个属性,对应表中的一个字段;在二维表中凡能唯一标识元组的最小属性集称为该表的键或码。(10)C 【解析】 “选课 SC“ 表是 “学生 S“ 表和 “课程 C“ 表的映射表,主键是两个表主键的组合。(11)D 【解析】 在 C 语言所有的运算符中,逗号运算符的优先级最低。C 语言中区分大小写,所以 APH 和 aph 是两个不同的变量。赋值表达式 a=b 表示将b 的值付给 a,而 b 本身的值保持不变;通过键盘可以向计算机输入允许的任何类型的数据。选项 D)中
32、当从键盘输入数据时,对于整型变量可以输入整型数值和字符,对于实型变量可以输入实型数值和整型数值等。(12)B 【解析】 C 语言规定用户标识符由字母、数字和下划线组成,且第一个字符必须是字母或下划线,可见选项 C),D)是错误的;此外,C 语言不允许用户将关键字作为标识符,而选项 A)中的 void 正是 C 语言的关键字。(13)B 【解析】 C 语言的语法规定,字母 e(E)之前必须有数字,且 e(E)后面的指数必须是整数,而选项 B)中,e(E)后面的指数是小数,所以不合法。(14)A 【解析】 在 C 语言中,“%“运算符两侧的运算数必须是整型。(15)A 【解析】 赋值运算符左侧的操
33、作数必须是一个变量,而不能是表达式或者常量,选项 C)和 D)错误。“%“运算符两侧都应当是整型数据,选项 B)错误。(16)D 【解析】 输出格式控制符%c 表示将变量以字符的形式输出;输出格式控制符%d 表示将变量以带符号的十进制整型数输出,所以第一个输出语句输出的结果为 a,97;第二个输出语句输出的结果为 k=12。-_(17)B 【解析】 C 语言的字符以其 ASCII 码的形式存在,所以要确定某个字符是大写字母,只要确定它的 ASCII 码在A和Z之间就可以了,选项 A)和 C)符合要求。函数 isalpha 用来确定一个字符是否为字母,大写字母的 ASCII 码值的范围为 65
34、到 90,所以如果一个字母的 ASCII 码小于 91,那么就能确定它是大写字母。(18)B 【解析】 满足表达式(c=2 if(ab) a=b; c=a; if(c!=a) c=b; printf(“%d,%d,%dn“,a,b,c);-_其输出结果是 A)程序段有语法错 B)3,5,3 C)3,5,5 D)3,5,7(20)若有定义:float x=1.5;int a=1,b=3,c=2;,则正确的 switch 语句是 A)switch(x) case 1.0:printf(“*n“); case 2.0:printf(“*n“); B)switch(int)x);case 1:prin
35、tf(“*n“); case 2:printf(“*n“);C)switch(a+b) case 1:printf(“*n“); case 2+1:printf(“*n“); D)switch(a+b)case1:printf(*n); casec:printf(*n);(21)有以下程序 #include main0 int y=9; for( ; y0;y-) if(y%3=0) printf(“%d“,-y); 程序的运行结果是 A)741 B)963 C)852 D)875421(22)以下描述中正确的是 A)由于 do-while 循环中循环体语句只能是一条可执行语句,所以循环体内不
36、能使用复合语句 -_B)do-while 循环由 do 开始,用 while 结束,在 while(表达式)后面不能写分号 C)在 do-while 循环体中,是先执行一次循环,再进行判断 D)do-while 循环中,根据情况可以省略 while(23)有以下程序 #include main() int a =1,2,3,4,y,*p= -p; y=*p;printf(“y=%dn“,y); 程序的运行结果是 A)y=0 B)y=1 C)y=2 D)y=3(24)以下数组定义中错误的是 A)int x3=0; B)int x23=l,2,3,4,5,6; C)int x3=l,2,3,4,5
37、,6; D)int x23=l,2,3,4,5,6;(25)下面说明不正确的是 A)char a10=“china“; B)char a10,*p=a;p=“china“ C)char *a;a=“china“ D)char a10,*p;p=a=“china“(26)若有定义:int a23;,以下选项中对 a 数组元素正确引用的是 A)a2!1 B)a23 C)a03 D)a12!1(27)若要求从键盘读入含有空格字符的字符串,应使用函数 A)getc() B)gets() C)getchar() D)scanf()(28)阅读下列程序段,则程序的输出结果为 #include “stdio
38、.h“ #define M(X,Y)(X)*(Y) #define N(X,Y)(X)/(Y) main() int a=5,b=6,c=8,k; k=N(M(a,b),c); printf(“%dn“,k); A)3 B)5 C)6 D)8-_(29)在 16 位 IBM-PC 机上使用 C 语言,若有如下定义 struct data int i; char ch; double f; b; 则结构变量 b 占用内存的字节数是 A)1 B)2 C)7 D)11(30)有以下程序 #include main() FILE *fp; int i,a6=l,2,3,4,5,6; fp=fopen(
39、“d3.dat“,“w+b“); fwrite(a,sizeof(int),6,fp); fseek(fp,sizeof(int)*3,SEEK_SET);/*该语句使读文件的位置指针从文件头向后移动 3 个 int 型数据*/fread(a,sizeof(int),3,fp); fclose(fp); for(i=0;i main() int s12=1,2,3,4,4,3,2,1,1,1,2,3,c5=0,i; for(i=0;i void fun(int *a,int n)/*fun 函数的功能是将 a 所指数组元素从大到小排序*/ int t,i,j; for(i=0;i #inclu
40、de main() char *p1=“abc“,*p2=“ABC“,str50= “xyz“; strcpy(str+2,strcat(p1,p2); printf(“%sn“,str);A)xyzabcABCB)zabcABC C)xyabcABCD)yzabcABC(34)以下函数返回 a 所指数组中最小的值所在的下标值 fun(int *a, int n) int i,j=0,p; p=j; for(i=j;i void abc(char*str) int a,b; for(a=b=0;stra!=0;a+)if(stra!=c) strb+=stra; strb=0; void ma
41、in() char str=“abcdef“; abc(str); printf(“str=%s“,str); A)str=abdef B)str=abcdef C)str=a D)str=ab(36)有以下程序 #include #include typedef struct char name9; char sex; float score2; STU; void f(STU a) STU b=“Zhao“,m,850,900; int i; strcpy(a.name,b.name); a.sex=b.sex; for(i=0;i main() FILE *fp; int a10=1,2
42、,3,i,n; fp=fopen(“d1.dat“,“w“); for(i=0;i void fun(char *t,char *s) while(*t!=0) t+; while(*t+=*s+)!=0); main() char ss10=“acc“,aa10=“bbxxyy“; fun(ss,aa); printf(“%s,%sn“,ss,aa); 程序的运行结果是 A)accxyy,bbxxyy B)acc,bbxxyy C)accxxyy,bbxxyy D)accbbxxyy,bbxxyy二、填空题请将每一个空的正确答案写在答题卡序号的横线上,答在试卷上不给分。(1)需求分析的最终结
43、果是产生 【1】 。(2)为了便于对照检查,测试用例应由输入数据和预期的 【2】 两部分组成。(3)数据结构分为逻辑结构与存储结构,线性链表属于 【3】 。(4)某二叉树中度为 2 的结点有 18 个,则该二叉树中有 【4】 个叶子结点。(5) 【5】 是数据库设计的核心。(6)已有定义:char c= ;int a=1,b;(此处 c 的初值为空格字符),执行b=!c后 b 的值为 【6】 。-_(7)设变量已正确定义为整型,则表达式 n=i=2,+i,i+的值为 【7】 。(8)下面程序的功能是:计算 1 10 之间的奇数之和与偶数之和,请填空。 #include main() int a
44、,b,c,I; a=c=0; for(I=0;I void swap(int *a, int *b) int *t; t=a; a=b; b=t; main() int i=3,j=5,*p= swap(p,q); printf(“%d %dn“,*p,*q); -_(11)下面程序的运行结果是 【12】 。 #include #define SIZE 12 main() char sSIZE; int I;for(I=0;I main() int a5=2,4,6,8,10,*p; p=a; p+; printf(“%d“,*p); (13)设有定义“struct int a; float b; char c; abc, *p_abc=“,则对结构体成员 a 的引用方法可以是 abc.a 和 p_abc 【14】 a。(14)以下程序的运行结果是 【15】 。 #include main() FILE *fp;