哪位朋友有20109月份全国计算机二级c语言程序比试加机试的题库有的话发我邮箱不胜感激!!!

"全国计算机二级c语言难吗"的糗事
11173 好笑
你可能感兴趣:
糗事百科为大家收集了很多的全国计算机二级c语言难吗的糗事,各种关于全国计算机二级c语言难吗的爆笑经历、尴尬时刻和开心视频,想持续关注全国计算机二级c语言难吗的糗事就收藏本页吧.计算机二级c语言笔试加机试题库详解_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
计算机二级c语言笔试加机试题库详解
总评分4.0|
浏览量2186765
用知识赚钱
&&知识点与习题总结
试读已结束,如果需要继续阅读或下载,敬请购买
定制HR最喜欢的简历
你可能喜欢
您可以上传图片描述问题
联系电话:
请填写真实有效的信息,以便工作人员联系您,我们为您严格保密。2012年3月份全国计算机等级考试二级C语言题库(笔试+机试) - 副本-共享资料网
2012年3月份全国计算机等级考试二级C语言题库(笔试+机试) - 副本
2012 年 3 月份全国计算机等级考试二级 C 语言笔试题库第一套一、选择题 在下列各题的 A) 、B) 、C) 、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应 位置上,答在试卷上不得分。 (1)为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种 图称为 A)PAD 图 B)N-S 图 C)结构图 D)数据流图 (2)结构化程序设计主要强调的是 A)程序的规模 B)程序的效率 C)程序设计语言的先进性 D)程序易读性 (3)为了使模块尽可能独立,要求 A)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量强 块间的耦合程度要尽量弱 B)模块的内聚程度要尽量高,且各模C)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量弱D)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量强 (4)需求分析阶段的任务是确定 A)软件开发方法 B)软件开发工具 C)软件开发费用 D)软件系统功能 (5)算法的有穷性是指 A)算法程序的运行时间是有限的 的 B)算法程序所处理的数据量是有限的 C)算法程序的长度是有限D)算法只能被有限的用户使用(6)对长度为 n 的线性表排序,在最坏情况下,比较次数不是 n(n-1)/2 的排序方法是 A)快速排序 B)冒泡排序 C)直接插入排序 D)堆排序 D) 任意顺序 (7)如果进栈序列为 e1,e2,e3,e4,则可能的出栈序列是 A)e3,e1,e4,e2 B)e2,e4,e3,e1 C)e3,e4,e1,e2 (8)将 E-R 图转换到关系模式时,实体与联系都可以表示成 A)属性 B)关系 C)键 D)域 (9)有三个关系 R、S 和 T 如下: R B a b C 0 1 D k1 n1S B f a n C 3 0 2 D h2 k1 x1T B a C 0 D k1由关系 R 和 S 通过运算得到关系 T,则所使用的运算为 A)并 B)自然连接 C)笛卡尔积 D)交 (10)下列有关数据库的描述,正确的是 A)数据处理是将信息转化为数据的过程 B)数据的物理独立性是指当数据的逻辑结构改变时,数据的存储结构不变 C)关系中的每一列称为元组,一个元组就是一个字段 D)如果一个关系中的属性或属性组并非该关系的关键字,但它是另一个关系的关键字,则称其为本关系 的外关键字 (11)以下叙述中正确的是 A)用 C 程序实现的算法必须要有输入和输出操作 入 算法可以既没有输入也没有输出 (12)下列可用于 C 语言用户标识符的一组是 A)void, define, WORD B)a3_3,_123,Car C)For, -abc, IF Case D)2a, DO, sizeof (13)以下选项中可作为 C 语言合法常量的是 A)-80 B)-080 C)-8e1.0 D)-80.0e B) 定义 line 是一个指针变 (14)若有语句:char *line[5];,以下叙述中正确的是 A) 定义 line 是一个数组,每个数组元素是一个基类型为 char 为指针变量 量,该变量可以指向一个长度为 5 的字符型数组 符 D) 定义 line 是一个指向字符型函数的指针 B)char A=65+1,b=′b′; C)float a=1,*b=&a,*c=&b; (15)以下定义语句中正确的是 A)int a=b=0; D)double C) 定义 line 是一个指针数组,语句中的*号称为间址运算 B)用 C 程序实现的算法可以没有输出但必须要有输 D)用 C 程序实现的 C)用 C 程序实现的算法可以没有输入但必须要有输出a=0?0 ;b=1.1; (16)有以下程序段 char ch=′a′; k=12; printf(&%c,%d,&,ch,ch,k); printf(&k=%d \n&,k); 已知字符 a 的 ASCII 码值为 97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 值或不定值 C)a,97,12k=12 (17)有以下程序 main() { int i,s=1; D)a,97,k=12 B)输出项与格式描述符个数不符,输出为零for (i=1;i&50;i++) if(!(i%5)&&!(i%3)) printf(&%d\n&,s);} 程序的输出结果是 A)409 B)277 C)1 D)91 (18)当变量 c 的值不为 2、4、6 时,值也为&真&的表达式是 A)(c==2)||(c==4)||(c==6) D)(c&=2&& c&=6)&&(c%2!=1) (19)若变量已正确定义,有以下程序段 int a=3,b=5,c=7; B)(c&=2&& c&=6)||(c!=3)||(c!=5) C)(c&=2&&c&=6)&&!(c%2) s+=i; if(a&b) if(c!=a) 其输出结果是a=b; c=b;c=a;printf(&%d,%d,%d\n&,a,b,c);A)程序段有语法错 (20)有以下程序 #include &stdio.h& main() { int x=1,y=0,a=0,b=0;B)3,5,3C)3,5,5D)3,5,7switch(x) { case 1:switch(y) { case 0:a++;case }1:b++;case 2:a++; b++; case 3:a++; b++; } printf(&a=%d,b=%d\n&,a,b); } 程序的运行结果是 A)a=1,b=0 B)a=2,b=2 C)a=1,b=1 D)a=2,b=1 (21)下列程序的输出结果是 #include &stdio.h& main() { int i,a=0,b=0;for(i=1;i&10;i++) { if(i%2==0) {a++;} b++;} printf(&a=%d,b=%d&,a,b); } A)a=4,b=4 (22)已知 #int t=0; while (t=1) {...} 则以下叙述正确的是 A)循环控制表达式的值为 0 上说法都不对 (23)下面程序的输出结果是 main() { int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a; printf(&%d\n&,*(p+2));} B)循环控制表达式的值为 1 C)循环控制表达式不合法 D)以 B)a=4,b=5 C)a=5,b=4 D)a=5,b=5 A)3B)4C)1D)2(24)以下错误的定义语句是 A)int C)int x[][3]={{0},{1},{1,2,3}}; B)int x[4][3]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}}; D)int x[][3]={1,2,3,4};x[4][]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}};(25)有以下程序 void ss(char *s,char t) { { while(*s) if(*s==t)*s=t-′a′+′A′;s++; } } main() { char str1[100]=&abcddfefdbd&,c=′d′;ss(str1,c); printf(&%s\n&,str1);} 程序运行后的输出结果是 A)ABCDDEFEDBD (26)有如下程序 main() { char ch[2][5]={&6937&,&8254&},*p[2]; B)abcDDfefDbD C)abcAAfefAbA D)Abcddfefdbdint i,j,s=0; for(i=0;i&2;i++)p[i]=ch[i]; for(i=0;i&2;i++) for(j=0;p[i][j]&′\0′;j+=2) s=10*s+p[i][j]-′0′; printf(&%d\n&,s);} 该程序的输出结果是 A)69825 B)63825 C)6385 D)693825 (27)有定义语句:char s[10];,若要从终端给 s 输入 5 个字符,错误的输入语句是 A)gets(&s[0]); B)scanf(&%s&,s+1); C)gets(s); D)scanf(&%s&,s[1]); (28)以下叙述中错误的是 A)在程序中凡是以&#&开始的语句行都是预处理命令行 束 C)#define MAX 是合法的宏定义命令行 行的过程中进行的 (29)设有以下说明语句 typedef struct { char ch[8]; } PER; 则下面叙述中正确的是 A)PER 是结构体变量名 结构体类型名 (30)以下叙述中错误的是 A)gets 函数用于从终端读入字符串 C)fputs 函数用于把字符串输出到文件 (31)以下能正确定义一维数组的选项是 B)getchar 函数用于从磁盘文件读入字符 D)fwrite 函数用于以二进制形式输出数据到文件 B)PER 是结构体类型名 C)typedef struct 是结构体类型 D)struct 是 B)预处理命令行的最后不能以分号表示结 D)C 程序对预处理命令行的处理是在程序执 A)int a[5]={0,1,2,3,4,5}; a[5]=&0123&; (32)有以下程序 #include&string.h& main() {B)char a[]={′0′,′1′,′2′,′3′,′4′,′5′,′\0′};C)char a={′A′,′B′,′C′};D)intchar p[]={′a′, ′b′, ′c′},q[10]={ ′a′, ′b′, ′c′};printf(&%d%d\n&,strlen(p),strlen(q));} 以下叙述中正确的是 A) 在给 p 和 q 数组置初值时,系统会自动添加字符串结束符,故输出的长度都为 3 B) 由于 p 数组中没有字符串结束符,长度不能确定,但 q 数组中字符串长度为 3 C) 由于 q 数组中没有字符串结束符,长度不能确定,但 p 数组中字符串长度为 3 D) 由于 p 和 q 数组中都没有字符串结束符,故长度都不能确定 (33)有以下程序 #include &stdio.h& #include &string.h& void { fun(char ?* ?*s[],int int n) i,j;charfor(i=0;i&n-1;i++) for(j=i+1;j&n;j++) if(strlen(s[i])&strlen(s[j])) {t=s[i];s[i]:s[j];s[j]=t;} } main() { char ?*ss[]={&bcc&,&bbcc&,&xy&,&aaaacc&,&aabcc&}; printf(&%s,%s\n&,ss[0],ss[4]);fun(ss,5); }程序的运行结果是 A)xy,aaaacc (34)有以下程序 #include &stdio.h& int f(int { int x) return(3); B)aaaacc,xy C)bcc,aabcc D)aabcc,bccif(x==0||x==1) y=x?*x -f(x-2); return } main() {z=f(3); }printf(&%d\n&,z);程序的运行结果是 A)0 B)9 C)6 D)8 (35)下面程序段的运行结果是 char str[]=&ABC&,*p= printf(&%d\n&,*(p+3)); A)67 B)0 C)字符′C′的地址 D)字符′C′ (36)若有以下定义: struct link {struct link * } a,b,c,*p,*q; 且变量 a 和 b 之间已有如下图所示的链表结构:指针 p 指向变量 a,q 指向变量 c。则能够把 c 插入到 a 和 b 之间并形成新的链表的语句组是: A)a.next=c; c.next=b; D)(*p).next=q; (*q).next=&b; (37)对于下述程序,在方式串分别采用&wt&和&wb&运行时,两次生成的文件 TEST 的长度分别是 #include&stdio.h& void main() { FILE *fp=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 中的数据用二进制表示的形式是 ,变量 b 中的数据用二进制表示的形式是 。 若要求将 a 的高 4 位取反,低 4 位不变,所要执行的运算是 A)a^b B)a|b C)a&b D)a&&4 (39)下面的程序段运行后,输出结果是 int i,j,x=0; static int a[8][8]; for(i=0;i&3;i++) for(j=0;j&3;j++) a[i][j]=2*i+j; for(i=0;i&8;i++) x+=a[i][j]; printf(&%d&,x); A)9 B)不确定值 C)0 D)18 B)p.next=q; q.next=p. C)p-&next=&c; q-&next=p-&(40)下列程序执行后的输出结果是 void func(int *a,int b[]) { b[0]=*a+6; }main() { int a,b[5];a=0; b[0]=3; func(&a,b); printf(&%d\n&,b[0]);} A)6 B)7 C)8 D)9 二、填空题 请将每一个空的正确答案写在答题卡序号的横线上,答在试卷上不给分。 (1)测试的目的是暴露错误,评价程序的可靠性;而 【1】 的目的是发现错误的位置并改正错误。 【2】 个叶子结点。 (2)某二叉树中度为 2 的结点有 18 个,则该二叉树中有 【3】 。 【4】 【5】 。 之间。(3)当循环队列非空且队尾指针等于队头指针时,说明循环队列已满,不能进行入队运算。这种情况称为 (4)在关系模型中,把数据看成一个二维表,每一个二维表称为一个 (5)在计算机软件系统的体系结构中,数据库管理系统位于用户和 (6)以下程序的输出结果是 main() { char c=′z′; printf(&%c&,c-25); } (7)阅读下面语句,则程序的执行结果是 #include &stdio.h& main() { int a=-1,b=1,k; 【7】 。 【6】 。if((++a&0)&&!(b--&=0)) printf(&%d,%d\&,a,b); else printf(&%d,%d\n&,b,a);} (8)下列程序的输出结果是 main() { 【8】 。for(i=1;i+1;i++) { { if(i&4) printf(&%d\n&,i); } printf(&%d\n&,i++);}} (9)以下程序的定义语句中,x[1]的初值是 #include &stdio.h& main() { int x[]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16},?*p[4],i; 【9】 ,程序运行后输出的内容是 【10】 。for(i=0;i&4;i++) { p[i]=&x[2*i+1];printf(&%d&,p[i][0]); } printf(&\n&);) } (10)以下程序的输出结果是 #include &stdio.h& void { int swap(int ?*t; a=b; b=t; ?*a, int ?*b) 【11】 。t=a; }main() {inti=3,j=5,?*p=&i,?*q=&j; printf(&%d %d\N,*p,*q)) 【12】 。swap(p,q); }(11)以下程序的输出结果是 main() { char s[]=&ABCD&, *p;for(p=s+1; p&s+4; p++)printf (&%s\n&,p);} (12)以下程序的输出结果是 float fun(int x,int y) { return(x+y);} 【13】 。main() { int a=2,b=5,c=8;printf(&%3.0f\n&,fun((int)fun(a+c,b),a-c));} (13)有如下图所示的双链表结构,请根据图示完成结构体的定义: lhead struct aa { 【14】 } 【15】 。 data rchild(14)fseek 函数的正确调用形式是 一、选择题 (1)B【解析】 N-S 图是由 Nassi 和 Shneiderman 提出的一种符合程序化结构设计原则的图形描述工具。 【解析】 结构化程序设计方法的主要原则可以概括为自顶向下、 逐步求精、 模块化及限制使用 goto它的提出是为了避免流程图在描述程序逻辑时的随意性上灵活性。 (2)D 语句,总的来说可使程序结构良好、易读、易理解、易维护。 (3)B【解析】 模块的独立程度可以由两个定性标准度量:耦合性和内聚性。耦合性是衡量不同模块彼此间互 相依赖(连接)的紧密程度;内聚性是衡量一个模块内部各个元素彼此结合的紧密程度。一般来说,要求模块之 间的耦合尽可能地低,而内聚性尽可能地高。 (4)D 【解析】 需求分析是软件定义时期的最后一个阶段,它的基本任务就是详细调查现实世界要处理的 对象(组织、部门、企业等),充分了解原系统的工作概况,明确用户的各种需求,然后在此基础上确定新系统的 功能。选项 A)软件开发方法是在总体设计阶段需完成的任务;选项 B)软件开发工具是在实现阶段需完成的 任务;选项 C)软件开发费用是在可行性研究阶段需完成的任务。 (5)A 【解析】 算法具有 5 个特性:① 有穷性:一个算法必须(对任何合法的输入值)在执行有穷步之后结 束,且每一步都可在有限时间内完成,即运行时间是有限的;② 确定性:算法中每一条指令必须有确切的含义, 读者理解时不会产生歧义;③ 可行性:一个算法是可行的,即算法中描述的操作都是可以通过已经实现的基本 运算执行有限次来实现;④ 输入:一个算法有零个或多个输入,这些输入取自于某个特定的对象的集合;⑤ 输 出:一个算法有一个或多个输出。 (6)D 【解析】 在最坏情况下,快速排序、冒泡排序和直接插入排序需要的比较次数都为 n(n-1)/2,堆排序 【解析】 由栈&后进先出&的特点可知:A)中 e1 不可能比 e2 先出,C)中 e1 不可能比 e2 先出,D)中栈 【解析】 关系数据库逻辑设计的主要工作是将?E -R? 图转换成指定 RDBMS 中的关系模式。首 需要的比较次数为 nlog2n。 (7)B 是先进后出的,所以不可能是任意顺序。B)中出栈过程如下图所示: (8)B 先,从 E-R 图到关系模式的转换是比较直接的,实体与联系都可以表示成关系,E-R 图中属性也可以转换成关 系的属性,实体集也可以转换成关系。 (9)D【解析】 在关系运算中,交的定义如下:设 R1 和 R2 为参加运算的两个关系,它们具有相同的度 n,且相对应的属性值取自同一个域,则 R1 R2 为交运算,结果仍为度等于 n 的关系,其中,交运算的结果既属于 R1, 又属于 R2。 (10)D 【解析】 数据处理是指将数据转换成信息的过程,故选项 A)叙述错误;数据的物理独立性是指数据 的物理结构的改变,不会影响数据库的逻辑结构,故选项 B)叙述错误;关系中的行称为元组,对应存储文件中 的记录,关系中的列称为属性,对应存储文件中的字段,故选项 C)叙述错误。 11)C 【解析】 算法具有的 5 个特性是:有穷性;确定性;可行性;有 0 个或多个输入;有一个或多个输出。 【解析】 C 语言规定标识符只能由字母、数字和下划线 3 种字符组成,且第一个字符必须为字母 所以说,用 C 程序实现的算法可以没有输入但必须要有输出。 (12)B 或下划线,排除选项 C)和 D);C 语言中还规定标识符不能为 C 语言的关键字,而选项 A)中 void 为关键字,故排 除选项 A)。 (13)A 【解析】 选项 B)项中,以 0 开头表示是一个八进制数,而八进制数的取值范围是 0~7,所以-080 是不 【解析】 C 语言中[ ]比*优先级高,因此 line 先与[5]结合,形成 line[5]形式,这是数组形式,它有 5 个 合法的;选项 C)和 D)中,e 后面的指数必须是整数,所以也不合法。 (14)A 变量。 (15)B 【解析】 本题考查变量的定义方法。如果要一次进行多个变量的定义,则在它们之间要用逗号隔 开,因此选项 A)和 D)错误。在选项 C)中,变量 c 是一个浮点型指针,它只能指向一个浮点型数据,不能指向指 针变量 b,故选项 C)错误。 (16)D 【解析】 输出格式控制符%c 表示将变量以字符的形式输出;输出格式控制符%d 表示将变量以带 【解析】 本题是计算 50 之内的自然数相加之和,题中 if 语句括号中的条件表达式!(i%5)&&!(i%3) 符号的十进制整型数输出,所以第一个输出语句输出的结果为 a,97;第二个输出语句输出的结果为 k=12。 (17)D 表明只有能同时被 5 和 3 整除的数才符合相加的条件,1~ 49 之间满足这个条件的只有,15、30 和 45,因为 s 的初始值为 1,所以 s=1+15+30+45=91。 (18)B 【解析】 满足表达式(c&=2&&c&=6)的整型变量 c 的值是 2,3,4,5,6。当变量 c 的值不为 2,4,6 时, 【解析】 两个 if 语句的判断条件都不满足,程序只执行了 c=a 这条语句,所以变量 c 的值等于 3, 【解析】 本题考查 switch 语句,首先,x=1 符合条件 case 1,执行 switch(y)语句,y=0 符合 case 0 语句, 其值只能为 3 或 5,所以表达式 c!=3 和 c!=5 中至少有一个为真,即不论 c 为何值,选项 B 中的表达式都为&真&。 (19)B 变量 b 的值没能变化,程序输出的结果为 3,5,3。所以正确答案为 B)。 (20)D 执行 a++并跳出 switch(y)语句,此时 a=1。因为 case 1 语句后面没有 break 语句,所以向后执行 case 2 语句,执 行 a++,b++,然后跳出 switch(x),得 a=2,b=1。 (21)B 环条件。 (22)B 【解析】t=1 是将 t 赋值为 1,所以循环控制表达式的值为 1。判断 t 是否等于 1 时,应用 t==1,注意 【解析】 在 C 语言中,数组元素是从 0 开始的。指针变量 p 指向数组的首地址,(p+2)就会指向数组 【解析】 本题考查的是二维数组的定义和初始化方法。C 语言中,在定义并初始化二维数组时,可 【解析】 在内存中,字符数据以 ASCII 码存储,它的存储形式与整数的存储形式类似。C 语言中,字 【解析】continue 语句的作用是跳过本次循环体中余下尚未执行的语句,接着再一次进行循环条件 的判定。当能被 2 整除时,a 就会增 1,之后执行 continue 语句,直接执行到 for 循环体的结尾,进行 i++,判断循 元素,然后再与 line 前面的&*&结合,表示此数组是一个指针数组,每个数组元素都是一个基类型为 char 的指针&=&与&==&的用法。 (23)A 中的第 3 个元素。题目中要求输出的是元素的值。 (24)C 以省略数组第一维的长度,但是不能省略第二维的长度。故选项 C)错误。 (25)B 符型数据和整型数据之间可以通用,也可以对字符型数据进行算术运算,此时相当于对它们的 ASCII 码进行 算术运算,在本题中,s++相当于 s=s+1,即让 s 指向数组中的下一个元素。 (26)C 【解析】 该题稍微难一点。主要要搞清楚以下几点:① 定义了一个指针数组 char *p[2]后,程序中第 一个循环 for(i=0;i&2;i++)p[i]=ch[i];的作用,是使指针数组的 p[0]元素(它本身是一个指针)指向了二维数组 ch 的第一行字符串,并使指针数组的 p[1]元素指向二维数组 ch 的第二行字符串,这样,就使指针数组 p 和二维数 组 ch 建立起了一种对应关系,以后对二维数组 ch 的某个元素的引用就有两种等价的形式:ch[i][j]或 p[i][j]。 ② 对二维数组 ch 的初始化,使其第一行 ch[0]中存入了字符串&6937&,第二行 ch[1]中的内容为字符串&8254&。 ③ 程序中第二个循环中的循环体 s=s*10+p[i][j]-'0';的功能是这样的,每执行一次,将 s 中的值乘以 10(也即,将 s 中的数值整体向左移动一位,并在空出来的个位上添一个 0),再将当前 p[i][j]中的字符量转换为相应的数字, 然后把这个数字加到 s 的个位上。④ 注意到内层循环的循环条件 p[i]?[j]& '是指 p[i][j]中的字符只要不是 '\0 字符串结束标志'\0'就继续循环,语句 j+=2;是使下标 j 每次增加 2,也即一个隔一个地从 p[i]所指向的字符 串中取出字符。经过上述解析后,不难看出,该程序首先从 p[0]所指向的字符串&6937&中一个隔一个地 取出字符,分别是'6'和'3',然后从 p[1]所指向的字符串&8254&中一个隔一个地取出字符,分别是'8'和'5', 同时经过转换和相加运算后,结果 s 中的值应该是 6385。 (27)D (28)D 【解析】 在格式输入中,要求给出的是变量的地址,而 D)答案中给出的 s[1]是一个值的表达式。 【解析】 C 语言中的预处理命令以符号#开头,这些命令是在程序编译之前进行处理的,选项 D)的 【解析】 本题中,typedef 声明新的类型名 PER 来代替已有的类型名,PER 代表上面指定的一个结构 【解析】 getchar 函数的作用是从终端读入一个字符。 【解析】 选项 A)中,定义的初值个数大于数组的长度;选项 C)中,数组名后少了中括号;选项 D)中, 【解析】 在给 p 和 q 数组赋初值时,系统会自动添加字符串结束符,从题目中可以看出数组 p 和 q 【解析】 函数 fun(char *s[],int n)的功能是对字符串数组的元素按照字符串的长度从小到大排序。描述错误。 (29)B 体类型,此时,也可以用 PER 来定义变量。 (30)B (31)B整型数组不能赋予字符串。 (32)A 都有 3 个字符,所以长度均为 3。 (33)A 在主函数中执行 fun(ss,5)语句后,*ss[]={&xy&, &bcc&, &bbcc&, &aabcc&, &aaaacc&},ss[0],ss[4] 的输出结果为 xy,aaaacc。 (34)C 【解析】 函数 int f(int x)是一个递归函数调用,当 x 的值等于 0 或 1 时,函数值等于 3,其他情况下 【解析】 考查指向字符串的指针变量。在该题中,指针变量 p 指向的应该是该字符串中的首地 【解析】 本题考查链表的数据结构,必须利用指针变量才能实现,即一个结点中应包含一个指针变 【解析】 以&wt&方式写入的是字符文件,转义字符'\n'被看作两个字符来处理。而&wb&方式写入的 【解析】 本题考查的是位运算的知识,对于任何二进制数,和 1 进行异或运算会让其取反,而和 0 【解析】 本题主要考查的是用二维数组首地址和下标来引用二维数组元素的方法。通过分析可y=x2-f(x-2),所以在主函数中执行语句 z=f(3)时,y=3*3-f(3-2)=9-f(1)=9-3=6。 (35)B 址,p+3 指向的是字符串结束标志'\0'的地址,因而*(p+3)的值为 0。 (36)D 量,用它存放下一结点的地址。 (37)B 是二进制文件,转义字符'\n'是一个字符。 (38)A 进行异或运算不会产生任何变化。 (39)C 知,程序中的双重循环定义了一个如下的二维数组: 0 2 4 1 3 5 2 4 6由于数组的下标是从 0 开始的,所以二维数组元素 a[i][j]表示的是二维数组 a 的第 i+1 行、 j+1 列对应位置 第 的元素。 (40)A 【解析】 函数的参数不仅可以是整型、实型、字符型等数据,还可以是指针型。它的作用是将一 个变量的地址传递到另一个函数中。 当数组名作参数时,如果形参数组中的各元素的值发生变化,实参数组元 素的值也将随之发生变化。 二、填空题 (1)【1】调试 【解析】 软件测试的目标是在精心控制的环境下执行程序,以发现程序中的错误,给出程序 可靠性的鉴定;调试也称排错,它是一个与测试既有联系又有区别的概念。具体来说,测试的目的是暴露错误, 评价程序的可靠性,而调试的目的是发现错误的位置,并改正错误。 (2)【2】19 (3)【3】 上溢 【解析】 在任意一棵二叉树中,度为 0 的结点(即叶子结点)总是比度为 2 的结点多一个。 【解析】 入队运算是指在循环队列的队尾加入一个新元素。这个运算有两个基本操作:首先将队尾指针进一(即 rear=rear+1),并当 rear=m+1 时,置 rear=1;然后将新元素插入队尾指针指向的位置。 当循环队列非空(s=1)且队尾指针等于队头指针时,说明循环队列已满,不能进行入队运算,这种情况称为&上 溢&。 (4)【4】 关系 记录值。 (5)【5】 操作系统或 OS 【解析】 数据库管理系统是数据库的机构,它是一种系统软件,负责数据库中 的数据组织、数据操纵、数据维护、控制及保护和数据服务。位于用户和操作系统之间。 (6)【6】 a (7) 7】 1,0 【 【解析】 'z'的 ASCII 码值为 122,经过 c-25 运算后,得 97,以字符形式输出是 a。 【解析】 与运算两边的语句必须同时为真时,结果才为真。 当执行完 if((++a&0)&&!(b--&=0)) 【解析】 本题考查了 for 循环语句的使用,break 语句用在本题中是结束 for 循环直 【解析】 在关系模型中,把数据看成一个二维表,每一个二维表称为一个关系。表中的每 一列称为一个属性,相当于记录中的一个数据项,对属性的命名称为属性名;表中的一行称为一个元组,相当于时,a,b 的值已经发生了变化。 (8)【8】 1 3 5 接跳出循环体外。当 i=1 时,因为 if 语句条件不满足,所以直接执行 printf(&%d\n&,i++);输出 1,同时 i 自加 1; 执行第二次 for 循环时,i=3;同样的 if 语句条件不满足,所以直接执行 printf(&%d\n&,i++);输出 3,同时 i 自 加 1;执行第三次 for 循环时,i=5,if 语句条件满足,所以执行 printf(&%d\n&,i),输出 5,然后 break 语句跳出 了 for 循环。(9)【9】 2 【10】 2 4 6 8 【解析】 在主函数中根据整型数组 x[]的定义可知,x[1]的初值等于 2。在 for 循环语句中, 当 i=0 时 ,p[0]=&x[1],p[0][0]=2; 当 i=1 时 ,p[1]=&x[3],p[1][0]=4; 当 i=2 时 ,p[2]=&x[5],p[2][0]=6; 当 i=3 时,p[3]=&x[7],?p[3][0]?=8, 所以程序输出的结果为 2、4、6、8。 (10)【11】 35 【解析】 函数 swap(int *a,int *b)的功能是实现*a 和*b 中两个数据的交换,在主函数中调 用 swap(p,q)后,形参指针变量 a 和 b 分别指向 i 和 j,在 swap(int *a,int *b)执行完后,指针变量 a 和 b 分别指向 j 和 i,而指针变量 p,q 所指向变量的值没有发生变化,所以输出结果为 35。 (11)【12】 BCD 行循环语句。 (12)【13】 9 【解析】 本题考查函数的综合知识。首先,我们可以利用强制转换类型转换运算符,将一 个表达式转换成所需类型。如:(double)a 是将 a 转换成 double 类型;(int)(x+y)是将 x+y 的值转换成整型。 本题可按部就班地逐步运算: fun((int)fun(a+c,b),a-c) fun((int)fun(10,5),2-8) fun((int)15.) fun(15,-6) 9 (13)【14】 struct aa *lhead,* 【解析】 结构体对链表的定义。 【解析】 本题考查函数 fseek 的用法。fseek 函数的调用形式 CD D 【解析】 本题考查指向字符串的指针的运算方法。指针变量 p 首先指 向字符串中的第一个字符 A,执行 p=s+1 后,p 指向字符串中的第二个字符 B,然后输出值&BCD&并换行,依次执(14)【15】 fseek(文件指针,位移量,起始点) 为: fseek(文件指针,位移量,起始点) &起始点&用 0,1 或 2 代替,其中,0 代表&文件开始&;1 为&当前位置&;2 为&文件末尾&。&位移量&指以&起始点&为 基点,向前移动的字节数。 ANSI C 和大多数 C 版本要求位移量是 long 型数据,这样当文件的长度大于 64k 时 不致出现问题。?ANSI C? 标准规定在数字的末尾加一个字母 L,就表示 long 型。第二套一、选择题 在下列各题的 A) 、B) 、C) 、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应 位置上,答在试卷上不得分。 (1)程序流程图中带有箭头的线段表示的是 A)图元关系 B)数据流 C)控制流 D)调用关系 (2)下面不属于软件设计原则的是 A)抽象 B)模块化 C)自底向上 D)信息隐蔽 (3)下列选项中,不属于模块间耦合的是 A)数据耦合 B)标记耦合 C)异构耦合 D)公共耦合 (4)下列叙述中,不属于软件需求规格说明书的作用的是 A)便于用户、 开发人员进行理解和交流 C)作为确认测试和验收的依据 (5)算法的时间复杂度是指 A)执行算法程序所需要的时间 D)算法程序中的指令条数 (6)已知数据表 A 中每个元素距其最终位置不远,为节省时间,应采用的算法是 A)堆排序 能是 A)ABCED B)DCBEA C)DBCEA D)CDABE (8)数据库设计包括两个方面的设计内容,它们是 A)概念设计和逻辑设计 计和行为特性设计 (9)关系表中的每一横行称为一个 A)元组 B)字段 C)属性 D)码 (10)设有表示学生选课的三张表,学生 S(学号,姓名,性别,年龄,身份证号),课程 C(课号,课名), 选课 SC(学号,课号,成绩),则表 SC 的关键字 (键或码)为 A)课号,成绩 (11)以下不正确的叙述是 A)在 C 程序中,逗号运算符的优先级最低 B)在 C 程序中,APH 和 aph 是两个不同的变量 C)若 a 和 b 类型相同,在计算了赋值表达式 a=b 后 b 中的值将放入 a 中,而 b 中的值不变 D)当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值 (12)请选出可用作 C 语言用户标识符的是 A)void,define,WORD D)2a,Do,Sizeof (13)以下选项中,不能作为合法常量的是 A)1.234e04 B)1.234e0.4 C)1.234e+4 D)1.234e0 B)a3_b3,_123,IF C)FOR,--abc,Case B)学号,成绩 C)学号,课号 D)学号,姓名,成绩 B)模式设计和内模式设计 C)内模式设计和物理设计 D)结构特性设 B)直接插入排序 C)快速排序 D)B)和 C) (7)栈底至栈顶依次存放元素 A、B、C、D,在第五个元素 E 入栈前,栈中元素可以出栈,则出栈序列可 B)算法程序的长度 C)算法执行过程中所需要的基本运算次数 B)反映出用户问题的结构, 可以作为软件开发工作的基础和依据 D)便于开发人员进行需求分析 (14)在 C 语言中,运算对象必须是整型数的运算符是 A)% B)\ C)%和\ D)** (15)若变量均已正确定义并赋值,以下合法的 C 语言赋值语句是 A)x=y==5; (16)有以下程序段 char ch=′a′; int k=12; printf(&k=%d \n&,k); B)x=n%2.5; C)x+n=i; D)x=5=4+1;printf(&%c,%d,&,ch,ch,k);已知字符 a 的 ASCII 码值为 97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 值或不定值 C)a,97,12k=12 D)a,97,k=12 B)输出项与格式描述符个数不符,输出为零(17)已知字母 A 的 ASCII 代码值为 65,若变量 kk 为 char 型,以下不能正确判断出 kk 中的值为大写字母的 表达式是 A)kk&=′A′&& kk&=′Z′ D)isalpha(kk)&&(kk&91) (18)当变量 c 的值不为 2、4、6 时,值也为&真&的表达式是 A)(c==2)||(c==4)||(c==6) D)(c&=2&& c&=6)&&(c%2!=1) (19)若有条件表达式 (exp)?a++:b--,则以下表达式中能完全等价于表达式(exp)的是 A)(exp==0) B)(exp!=0) C)(exp==1) D)(exp!=1) D)char (20)以下不正确的定义语句是 A)double x[5]={2.0,4.0,6.0,8.0,10.0}; c2[]={′\x10′, ′xa′, ′\x8′}; (21)下列程序执行后的输出结果是 main() { int a[3][3], *p,i; p=&a[0][0]; for(i=1; i&9; i++)p[i]=i+1; printf(&%d\n&,a[1][2];) A)3 B)6 C)9 D)随机数 B)int y[5]={0,1,3,5,7,9}; C)char c1[]={′1′,′2′,′3′,′4′,′5′}; B)(c&=2&& c&=6)||(c!=3)||(c!=5) C)(c&=2&&c&=6)&&!(c%2) B)!(kk&=′A′||kk&=′Z′) C)(kk+32)&=′a′&&(kk+32)&=′Z′(22)设有以下程序段 int x=0,s=0; while(!x!=0)s+=++x; printf(&%d&,s); 则 A)运行程序段后输出 0 序段执行无限次 (23)(23)下面程序段的运行结果是 char *s=&abcde&; s+=2;printf(&%d&,s); A)cde B)字符′c′ C)字符′c′的地址 D)无确定的输出结果 B)运行程序段后输出 1 C)程序段中的控制表达式是非法的 D)程 (24)阅读下列程序,则执行后的结果为 #include &stdio.h& main() { int c[][4]={1,2,3,4,5,6,7,34,213,56,62,3,23,12,34,56};printf(&%x,%x\n&,c[2][2],*(*(c+1)+1));} A)3e,6 B)62,5 C)56,5 D)3E,6(25)下面判断正确的是 A)char *a=&china&;等价于 char *a;*a=&china&; C)char *s=&china&; 等 价 于 c[4]=d[4]=&abc&; (26)若有定义:int A)a[2][!1] a[2][3];,以下选项中对 a 数组元素正确引用的是 C)a[0][3] D)a[1&2][!1] char *s;s=&china&; B)char str[5]={&china&};等价于 char str[]={&china&}; D)char c[4]=&abc&,d[4]=&abc&; 等 价 于 charB)a[2][3](27)有定义语句:char s[10];,若要从终端给 s 输入 5 个字符,错误的输入语句是 A)gets(&s[0]); (28)有以下程序 #include &stdio.h& #define #define #define main() { int i1,i2; N 5 M f(x) N+1 (x*M) B)scanf(&%s&,s+1); C)gets(s); D)scanf(&%s&,s[1]);i1=f(2); i2=f(1+1); printf(&%d %d\n&,i1,i2); } 程序的运行结果是 A)12 12 B)11 7 C)11 11 D)12 7 (29)若有以下说明和定义 union dt {} 以下叙述中错误的是 A)data 的每个成员起始地址都相同 (30)有以下程序 #include&stdio.h& main() {FILE *int k,n,a[6]={1,2,3,4,5,6}; fp=fopen(&d2.dat&,&w&); fprintf(fp,&%d%d%d\n&,a[0],a[1],a[2]); fprintf(fp,&%d%d%d\n&,a[3],a[4],a[5]); fclose(fp); B)变量 data 所占内存字节数与成员 c 所占字节数相等 D)data 可以作为函数的实参C)程序段:data.a=5;printf(&%f\n&,data.c);输出结果为 5.000000 fp=fopen(&d2.dat&,&r&); fscanf(fp,&%d%d&,&k,&n);printf(&%d%d\n&,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)a[p-a] B)*(&a[i]) C)p[i] D)a[10] (32)有以下程序 #include &stdio.h& void { int fun(int i,j,t; j=n2; {t=s[i];s[i]=s[j];s[j]=t;i++;j--;} ?*s ,int n1,int n2)i=n1;while(i&j) } main() { inta[10]={1,2,3,4,5,6,7,8,9,0},k; fun(a,4,9); fun(a,0,9); printf(&\n&);fun(a,0,3);for(k=0;k&l0;k++)printf(&%d&,a[k]); } 程序的运行结果是 A) B)C)D)(33)阅读下列程序,当运行函数时,输入 asd af aa z67,则输出为 #include &stdio.h& #include &ctype.h& #include &string.h& int fun (char *str) { int i,j=0; for(i=0;str[i]!=′ \0′;i++) if(str[i]!=′ ′)str[j++]=str[i]; str[j]= ′\0′; } main() { char str[81]; printf(&Input a string : &); gets(str); puts(str); fun(str); printf(&%s\n&,str); } A)asdafaaz67 (34)有以下程序 int fun(int n) {if(n==1)return 1; else return(n+fun(n-1)); } main() { scanf(&%d&,&x); x=fun(x);printf(&%d\n&,x) } 执行程序时,给变量 x 输入 10,程序的输出结果是 A)55 B)54 C)65 D)45 (35)下面程序段中,输出*的个数是 char *s=&\ta\018bc&; for(;*s!='\0';s++)printf(&*&); A)9 B)5 C)6 D)7 (36)C 语言结构体类型变量在程序运行期间 A)TC 环境在内存中仅仅开辟一个存放结构体变量地址的单元 C)只有最开始的成员驻留在内存中 D)部分成员驻留在内存中 (37)已知函数的调用形式为 fread(buf,size,count,fp),参数 buf 的含义是 A)一个整型变量,代表要读入的数据项总数 C)一个指针,指向要读入数据的存放地址 (38)设有以下语句 char x=3,y=6,z; z=x^y&&2; 则 z 的二进制值是 A) A)auto 和 register (40)设有定义语句 int B) C) D) D)static 和 register (39)在 C 语言中,只有在使用时才占用内存单元的变量,其存储类型是 B)extern 和 register C)auto 和 static (?*f)(int);, 以下叙述正确的是 则 B)f 是指向函数的指针变量,该函数具有一个 int 类型的形参 D)f 是函数名,该函数的返回值是基类型为 int 类型的地址 B)一个文件指针,指向要读的文件 B)所有的成员一直驻留在内存中 B)asd af aa z67 C)asd D)z67D)一个存储区,存放要读的数据项A)f 是基类型为 int 的指针变量C)f 是指向 int 类型一维数组的指针变量 二、填空题请将每一个空的正确答案写在答题卡序号的横线上,答在试卷上不给分。 (1)测试用例包括输入值集和 【1】 值集。 。 【3】 。 (2)在树形结构中,树根结点没有 【2】(3)数据结构分为逻辑结构与存储结构,线性链表属于 【4】 的联系。(4) 一个项目具有一个项目主管,一个项目主管可管理多个项目,则实体&项目主管&与实体&项目&的联系属于 (5)数据库设计分为以下 6 个设计阶段:需求分析阶段、 施阶段、运行和维护阶段。 (6)阅读下面程序段,则执行后输出的结果是 #include &stdio.h& main() { char fun(char,int); char a=′A′; int b=13; a=fun(a,b); putchar(a);} char fun(char a,int b) { 【6】 。【5】、逻辑设计阶段、物理设计阶段、实k=a+b;} (7)函数 fun 的返回值是 fun(char *a,char *b) { int num=0,n=0; while(*(a+num)!='\0')mm++; while(b[n]){*(a+num)=b[n];num++;n++;} } (8)以下程序的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排 列,函数返回删除后数组中数据的个数。 例如,若一维数组中的数据是: 2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10 删除后,数组中的内容应该是: 2 3 4 5 6 7 8 9 10。 请填空。 #include &stdio.h& #define N 80 int fun(int a[], int n) { int i,j=1; for(i=1;i&n;i++) if(a[j-1] 【8】 a[i]) 【7】a[j++]=a[i]; 【9】 ; } main() { int a[N]={ 2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10}, i, n=19; printf(&The original data : \n&); for(i=0; i&n; i++)printf(&%3d&,a[i]); n=fun(a,n); printf(&\nThe data after deleted: \n&); for(i=0; i&n; i++)printf(&%3d&,a[i]); printf(&\n\n&); } (9)以下程序的运行结果是 #include &stdio.h& main() { int x=1,y=0,a=0,b=0; 【10】 。switch(x) { case 1:switch(y) { case 1: 0:a++; b++;case }case 2:a++; b++; case 3:a++; b++; } printf(&a=%d,b=%d\n&,a,b); } (10)以下程序的输出结果是 fun (int x,int y,int z) { z =x*x+y*y;} main () { int a=31; 【11】 。fun (6,3,a) printf (&%d&, a) } (11)函数 my_cmp( )的功能是比较字符串 s 和 t 的大小,当 s 等于 t 时返回 0,否则返回 s 和 t 的第一个不 同字符的 ASCII 码差值,即 s&t 时返回正值,s&t 时返回负值。请填空。 My_cmp(char*s,char*t) { { while (*s == *t) if (*s == ′ \0)return0; 【12】++s; ++t; } return } (12)以下程序的输出结果是 void reverse(int a[],int n) { int i,t; for(i=0;i&n/2;i++) { t=a[i]; a[i]=a[n-1-i];a[n-1-i]=t;} } main() { int b[10]={1,2,3,4,5,6,7,8,9,10}; int i,s=0; reverse(b,8); for(i=6;i&10;i++)s+=b[i]; printf(& %d\n&,s); } 【13】 。 ; (13)以下说明语句中, typedef struct { char ch[8]; } PER;【14】是结构体类型名。(14)以下程序的作用是:从名为 filea.dat 的文本文件中逐个读入字符并显示在屏幕上。请填空。 #include &stdio.h& main() {FILE ?* char ); 【15】fp=fopen(ch=fgetc(fp); while(!feof(fp)) { putchar(ch); ch=fgetc(fp); }putchar('\n');fclose(fp); } 一、选择题 (1)C 【解析】 程序流程图是人们对解决问题的方法、思路或算法的一种图形方式的描述。其中,图框表 示各种操作的类型,图框中的文字和符号表示操作的内容;流程线表示操作的先后次序。 带箭头的线段在数据 流程图中表示数据流;带箭头的线段在程序流程图中表示控制流。 题中给出的选项中,在图元之间用带有箭头 的线段表示图元关系。在模块之间用带有箭头的线段表示调用关系。 (2)C 【解析】 软件设计遵循软件工程的基本目标和原则,建立了适用于在软件设计中应该遵循的基本原 理和与软件设计有关的概念,它们具有抽象、模块化、信息隐蔽和数据独立性。自底向上是集成测试中增量 测试的一种。 (3)C 【解析】 模块之间的耦合程度反映了模块的独立性,也反映了系统分解后的复杂程度。按照耦合程 度从强到弱分别是:内容耦合、公共耦合、外部耦合、控制耦合、标记耦合、数据耦合和非直接耦合,没有异 构耦合这种方式。 (4)D 【解析】 软件需求规格说明书(SRS,Software Requirement Specification)是需求分析阶段的最后成果, 是软件开发中的重要文档之一。它具有以下几个方面的作用:① 便于用户、开发人员进行理解和交流;② 反 映出用户问题的结构,可以作为软件开发工作的基础和依据;③ 作为确认测试和验收的依据。 (5)C 【解析】 算法的复杂度主要包括算法的时间复杂度和空间复杂度。所谓算法的时间复杂度是指执 行算法所需要的计算工作量,即算法执行过程中所需要的基本运算的次数;算法的空间复杂度一般是指执行 这个算法所需要的内存空间。 (6)B 【解析】 堆排序的比较次数为 nlog2n;直接插入排序的比较次数为 n(n-1)/2;快速排序的比较次数为 【解析】 栈操作原则上&后进先出&,栈底至栈顶依次存放元素 A、B、C、D,则表明这 4 个元素中 D 【解析】 数据库设计包括数据库概念设计和数据库逻辑设计两个方面的内容。 【解析】 关系表中,每一行称为一个元组,对应表中的一条记录;每一列称为一个属性,对应表中的一 【解析】 &选课 SC& 表是 &学生 S& 表和 &课程 C& 表的映射表,主键是两个表主键的组合。 nlog2n。当数据表 A 中每个元素 (7)B 是最后进栈,B、C 处于中间,A 最早进栈,所以出栈时一定是先出 D,再出 C,最后出 A。 (8)A (9)A个字段;在二维表中凡能唯一标识元组的最小属性集称为该表的键或码。 (10)C (11)D 【解析】 在 C 语言所有的运算符中,逗号运算符的优先级最低。C 语言中区分大小写,所以 APH和 aph 是两个不同的变量。赋值表达式 a=b 表示将 b 的值付给 a,而 b 本身的值保持不变;通过键盘可以向计 算机输入允许的任何类型的数据。选项 D)中当从键盘输入数据时,对于整型变量可以输入整型数值和字符, 对于实型变量可以输入实型数值和整型数值等。 (12)B 【解析】 C 语言规定用户标识符由字母、数字和下划线组成,且第一个字符必须是字母或下划线, 可见选项 C),D)是错误的;此外,C 语言不允许用户将关键字作为标识符,而选项 A)中的 void 正是 C 语言的关 键字。 (13)B 【解析】 C 语言的语法规定,字母 e(E)之前必须有数字,且 e(E)后面的指数必须是整数,而选项 B) 【解析】 在 C 语言中,&%&运算符两侧的运算数必须是整型。 【解析】 赋值运算符左侧的操作数必须是一个变量,而不能是表达式或者常量,选项 C)和 D)错误。 【解析】 输出格式控制符%c 表示将变量以字符的形式输出;输出格式控制符%d 表示将变量以带 【解析】 C 语言的字符以其 ASCII 码的形式存在,所以要确定某个字符是大写字母,只要确定它的 中,e(E)后面的指数是小数,所以不合法。 (14)A (15)A&%&运算符两侧都应当是整型数据,选项 B)错误。 (16)D 符号的十进制整型数输出,所以第一个输出语句输出的结果为 a,97;第二个输出语句输出的结果为 k=12。 (17)B ASCII 码在'A'和'Z'之间就可以了,选项 A)和 C)符合要求。函数 isalpha 用来确定一个字符是否为字母,大写字 母的 ASCII 码值的范围为 65 到 90,所以如果一个字母的 ASCII 码小于 91,那么就能确定它是大写字母。 (18)B 【解析】 满足表达式(c&=2&&c&=6)的整型变量 c 的值是 2,3,4,5,6。当变量 c 的值不为 2,4,6 时, 【解析】 条件运算符要求有 3 个操作对象,称三目(元)运算符,它是 C 语言中惟一的一个三目运算 其值只能为 3 或 5,所以表达式 c!=3 和 c!=5 中至少有一个为真,即不论 c 为何值,表达式 B)都为&真&。 (19)B 符。条件表达式的一般形式为:表达式 1?表达式 2:表达式 3 其求解顺序是:先求解表达式 1,若为非 0(真)则求 解表达式 2,此时表达式 2 的值就作为整个条件表达式的值。若表达式 1 的值为 0(假),则求解表达式 3,表达 式 3 的值就是整个条件表达式的值,注意++、--的用法。 (20)B 【解析】 在一维数组中要注意的是作为下标表达式的常量表达式的值必须是大于等于 0,选项 B) 【解析】 本题中,a[1][2]是二维数组中的第 6 个元素,对应 for 循环中 i 的值为 5,p[5]=5+1。 【解析】 本题中,&!&表示逻辑非运算符,&!=&表示不等于运算符,逻辑非运算符比不等于运算符的优 【解析】 对于字符串指针,其保留的是整个串的首地址,即第一个字符的起始地址;当该指针做算术 【解析】 数组 c[][4]表示一个 4 行 4 列数组,c[2][2]表示第 3 行第 3 列上的元素 62,*(*(c+1)+1))表 【解析】 选项 A)char *a;*a=&china&应改为?a=china?;, 选项 B)应该是 char str[6];D)项表述方法有 【解析】 C 语言中数组下标是从 0 开始的,所以二维数组 a[2][3]的第一维下标取值为 0、1;第二维 【解析】 在格式输入中,要求给出的是变易的地址,而 D)答案中给出的 s[1]是一个值的表达式。 【解析】 根据宏替换的替换规则,我们可知,f(2)=2*N+1=2*5+1=11,f(1+1)=1+1*N+1=1+1*5+1=7。 【解析】 选项 A),共用体的每个成员的起始地址都相同;选项 B),共用体变量所占的内存长度等于 中定义有 5 个元素,但赋值时有 6 个元素,所以是错误的。 (21)B (22)B 先级高。 (23)C 运算时,就是该指针根据其类型向后移动相应的存储空间。 (24)A 示第 2 行第 2 列上的元素 6,通过十六进制输出为 3e,6。 (25)C 错误。 (26)D 的下标取值为 0、1、2,因而选项 A)、B)、C)都是错误的,选项 D)表示数组元素 a[0][0]。 (27)D (28)B (29)D最长的成员的长度;选项 C)因为每个成员的起始地址相同,所以整型数 5 以浮点型输出时为 5.000000;选项 D)C 语言规定,不能把共用体变量作为函数的参数。 (30)D 符。 (31)D 【解析】 通常,引用一个数组元素可以用下标法,如 a[p-a]形式,或指针法,如*(&a[i])的形式。本题 【解析】 函数 fun(int *s,int n1,int n2)的功能是对数组 s 中的元素进行首尾互相调换。所以在主函 中 a[9]=9,a[10]显然超出数组范围,注意,数组的下标是从 0 开始的。 (32)C 数中,当 fun(a,0,3)执行完后,数组 a[12]={4,3,2,1,5,6,7,8,9,0};再执行 fun(a,4,9),数组 a[12]={4,3,2,1,0,9,8,7,6,5}; 再执行 fun(a,0,9)后,数组 a[12]={5,6,7,8,9,0,1,2,3,4}。 【解析】 将有 6 个元素的整型数组分两行输出到一个文件中,因为输出的都是数字并且每行都没 有分隔符,所以当再对其进行读取操作时,每一行都会被认为是一个完整的数,而换行符则作为它们的分隔 (33)A【解析】 本题题意要求删除所有空格,即除了空格以外的其他所有字符都要留下。由于 C 语言中没有直接删除字符的操作,所以我们对于删除字符的操作都是采用&留下&字符的算法,以前的题目亦是如此。 用 str[i]从串头到串尾逐一走动,每走到一个字符都判断其是否为空格,若不是空格(注意在 if()的单引号之间 有一个空格),则将其保存 str[j]中。注意 j 的下标变化、初值及最后加串结束符'\0'。 (34)A 【解析】 本程序考察的是函数的递归调用,在调用一个函数的过程中又出现直接或间接地调用该 【解析】 本题中,格式符 0 表示的是八进制无符号形式输出整型数(不带前导 0),字符常量在内存中 函数本身,称为函数的递归调用,执行结果为 1+2+3+4+5+6+7+8+9+10=55。 (35)C 占一个字节,存放的是 ACSII 码代码值。C 语言规定,所有字符常量都作为整型量来处理,在计算机内部,其对 应的整数值就是 ACSII 字符集中该字符的序号,即&*s 中有几个字符就输出几个*。 (36)B (37)C 【解析】 结构体类型的变量在程序运行期间要作为一个整体占用连续的内存单元。 【解析】 这是一道考查 fread 函数的题。buf 是一个指针,fread 是读入数据的存放地址;fwrite 是输 【解析】 本题考查两个位运算符。出数据的地址(以上指的是起始地址)。 (38)B 按位异或运算符&^&是双目运算符,其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相 异或时,结果为 1。 左移运算符&&&&是双目运算符,其功能把&&& &左边的运算数的各二进位全部左移若干位,由&&&&右边的数指 定移动的位数,高位丢弃,低位补 0,并且&&&&运算符的优先级于&^&。 (39)A (40)B 【解析】 在 C 语言中只有自动变量和寄存器变量在使用时才占用内存单元。 【解析】 本题考查的是指向函数的指针。语句 int (* f)(int);是对一个函数的声明,其中 f 是指向该函数的指针,该函数有一个整型的参数,函数返回值类型为整型。 二、选择题 (1)【1】 输出 【解析】 软件测试用例是为了有效发现软件缺陷面编写的包含测试目的、测试步骤、 期望测试结果的特定集合。 正确认识和设计软件测试用例可以提高软件测试的有效性,便于测试质量的度量, 增强测试过程的可管理性。软件测试用例包括:输入值集和输出值集。测试用例是软件测试的核心。 (2)【2】 前件 【解析】 在树形结构中,每一个结点只有一个前件,称为父结点;没有前件的结点只有一个, 【解析】 数据的逻辑结构是指反映数据元素之间逻辑关系的数据结构;数据的存储 称为树的根结点;每一个结点可以有多个后件,它们都称为该结点的子结点;没有后件的结点称为叶子结点。 (3)【3】 存储结构 结构是指数据的逻辑结构在计算机存储空间中的存放形式。在数据的存储结构中,不仅要存放各数据元素的 信息,还需要存放各数据元素之间前后件关系的信息。 (4)【4】 一对多(或 1∶ N) (5)【5】 概念设计阶段 【解析】 两个实体集间的联系实际上是实体集间的函数系,这种函数关系可 【解析】 数据库设计分为以下 6 个设计阶段:需求分析阶段、概念设计阶段、逻 以有 3 种,即一对一(1∶ 1)的联系、一对多(1∶ N)或多对一(N∶ 1)的联系和多对多(N∶ N)的联系。 辑设计阶段、物理设计阶段、实施阶段及数据库运行和维护阶段。 (6)【6】 N 【解析】 函数说明语句中的类型名必须与函数返回值的类型一致。本题实现的是在字符'A' 【解析】 本题首先通过第一个 while 循环计算字符串 a 的长度,再通 的 ASCII 码值上加上一个常数,使之变成另一个 ASCII 码值,从而输出字符。 (7)【7】 字符串 a 和 b 的长度之和 【9】 return j 过第二个循环,将字符串 a 和 b 相连,最后返回连接后的总长度。 8)【8】!= 【解析】 本题程序的流程是:让 i,j 都从 1 开始,其中 j 用于控制删除后剩下的 数中的下标,i 用于搜索原数组中的元素。 始终是新数组已有元素中最后一个元素的下一个元素的下标,所以 j if()中的条件是 a[j-1]!=a[i],其中 a[j-1]就是新数组中的最后一个元素,若条件成立则表示出现了不同的值,所以 a[i]要留到新数组中。注本题中 i、j 的初值都要从 1 开始,该算法只能用于数组已排序的题目中。 (9)【10】 a=2,b=1 【解析】 本题考查了 switch 结构的内容。C 语言中,程序执行完一个 case 标号的内 容后,如果没有 break 语句,控制结构会转移到下一个 case 继续执行,因为 case 常量表达式只是起语句标号作 用,并不是在该处进行条件判断。 本题程序在执行完内部 switch 结构后,继续执行了外部 switch 结构的 case 2: 分支,最后 a 和 b 的值分别为 2 和 1。 (10)【11】 31 (11)【12】 *s-*t 【解析】 在函数调用时,形参值的改变,不会改变实参值。 【解析】 两字符串大小比较必须从它们的首字符开始,在对应字符相等情况下循环,直至不相等结束。相等时,若字符串已到了字符串的结束标记符,则两字符串相同,函数返回 0 值;如还有后继字 符,则准备比较下一对字符。对应字符不相同,循环结束。循环结束时,就以两个当前字符的差返回,所以在空 框处应填入*s-*t,保证在 s & t 时,返回正值,当 s & t 时,返回负值。 (12)【13】 22 【解析】 在 main 函数中,调用 reverse 函数将 b 数组中的前 8 个成员进行互置,执行完毕 【解析】 本题中,typedef 声明新的类型名 PER 来代替已有的类型名,PER 代表上面指定 【解析】 fopen 函数的调用方式通常为 fopen(文件名,使用文件方式)。本题中 后,b 数组中的成员为{8,7,6,5,4,3,2,1,9,10},然后再执行 for 循环结构,将 b[6],b[7]...b[9]的值相加,结果为 22。 (13)【14】 PER 的一个结构体类型,此时,也可以用 PER 来定义变量。 (14)【15】 “filea.dat”,“r” 要求程序可以打开 filea.dat 文件,并且是要读取文件中的内容,所以空白处应当填入 &filea.dat&,&r&。第三套一、选择题 在下列各题的 A) 、B) 、C) 、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应 位置上,答在试卷上不得分。 (1)软件是指 文档的完整集合 (2)检查软件产品是否符合需求定义的过程称为 A)确认测试 B)集成测试 C)验证测试 D)验收测试 (3)以下不属于对象的基本特点的是 A)分类性 B)多态性 C)继承性 D)封装性 (4)在设计程序时,应采纳的原则之一是 A)不限制 goto 语句的使用 读者理解 (5)下列叙述中正确的是 A)程序执行的效率与数据的存储结构密切相关 C)程序执行的效率只取决于所处理的数据量 (6)数据结构中,与所使用的计算机无关的是数据的 A)存储结构 B)物理结构 C)逻辑结构 D)物理和存储结构 (7)线性表的顺序存储结构和线性表的链式存储结构分别是 A)顺序存取的存储结构、顺序存取的存储结构 C)随机存取的存储结构、随机存取的存储结构 (8)树是结点的集合,它的根结点数目是 A)有且只有 1 B)1 或多于 1 C)0 或 1 D)至少 2 (9)下列有关数据库的描述,正确的是 A)数据库是一个 DBF 文件 数据库是一组文件 (10)数据库、数据库系统和数据库管理系统之间的关系是 A)数据库包括数据库系统和数据库管理系统 C)数据库管理系统包括数据库和数据库系统 (11)以下 4 个选项中,不能看作一条语句的是 A); B)a=5,b=2.5,c=3.6; C)if(a&5); D)if(b!=5)x=2;y=6; B)数据库系统包括数据库和数据库管理系统 D)三者没有明显的包含关系 B)数据库是一个关系 C)数据库是一个结构化的数据集合 D) B)随机存取的存储结构、顺序存取的存储结构 D)任意存取的存储结构、任意存取的存储结构 B)程序执行的效率只取决于程序的控制结构 D)以上三种说法都不对 B)减少或取消注解行 C)程序越短越好 D)程序结构应有助于 A)程序 B)程序和文档 C)算法加数据结构 D)程序、数据与相关 (12)下面四个选项中,均是不合法的用户标识符的选项是 A)A P_0 do A)′C′ B)′′C′′ B)float la0_A C)′\xCC′ C)b-a goto int D) ′\072′ D)_123 temp int (13)以下选项中不属于字符常量的是 (14)设变量已正确定义并赋值,以下正确的表达式是 A)x=y*5=x+z B)int(15.8%5) C)x=y+z+5,++y D)x=25%5.0 (15)若变量已正确定义并赋值,以下符合 C 语言语法的表达式是 A)a:=b+1 B)a=b=c+2 C)int 18.5%3 D)a=a+7=c+b (16)以下程序的运行结果是 int k=0; void fun(int m) {m+=k;k+=m;printf(&m=%d main() {int i=4; fun(i++); } A)m=4 D)m=4 k=5 k=5 i=4 i=5 k=5 k=5 B)m=4 k=4 i=5 k=5 C)m=4 k=4 i=4 k=5 printf(&i=%d k=%d\n&,i,k); k=%d &,m,k++);}(17) 已有定义:,程序前面已在命令行中包含 ctype.h 文件,不能用于判断 c 中的字符是否为大写字母 的表达式是 A)isupper(c) (18)设有: int a=1,b=2,c=3,d=4,m=2,n=2; 执行 (m=a&b)&&(n=c&d)后,n 的值是 A)1 B)2 C)3 D)4 B)′A′&=c&=′Z′ C)′A′&=c&&c&=′Z′ D)c&=(′z′-32)&&(′a′-32)&=c(19)若变量已正确定义,有以下程序段 int a=3,b=5,c=7; a=b; c=b; c=a;if(a&b) if(c!=a) 其输出结果是printf(&%d,%d,%d\n&,a,b,c);A)程序段有语法错B)3,5,3C)3,5,5D)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:printf(&*\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 &stdio.h& main0 { int for( ; y=9; y&0;y--) printf(&%d&,--y);if(y%3==0) }程序的运行结果是 A)741 B)963 C)852 D)875421 (22)以下描述中正确的是 A)由于 do-while 循环中循环体语句只能是一条可执行语句,所以循环体内不能使用复合语句 B)do-while 循环由 do 开始,用 while 结束,在 while(表达式)后面不能写分号 C)在 do-while 循环体中,是先执行一次循环,再进行判断 (23)有以下程序 #include &stdio.h& main() { --p; } 程序的运行结果是 A)y=0 B)y=1 C)y=2 D)y=3 (24)以下数组定义中错误的是 A)int x[][3]={0}; x[2][3]={l,2,3,4,5,6}; (25)下面说明不正确的是 A)char a[10]=&china&; a[10],*p;p=a=&china& (26)若有定义:int A)a[2][!1] a[2][3];,以下选项中对 a 数组元素正确引用的是 C)a[0][3] D)a[1&2][!1] B)char a[10],*p=a;p=&china& C)char *a;a=&china& D)char B)int x[2][3]={{l,2},{3,4},{5,6}}; C)int x[][3]={{l,2,3},{4,5,6}}; D)int int a[ ]={1,2,3,4},y,?*p=&a[3]; y=?*p;printf(&y=%d \n&,y); D)do-while 循环中,根据情况可以省略 whileB)a[2][3](27)若要求从键盘读入含有空格字符的字符串,应使用函数 A)getc() B)gets() C)getchar() D)scanf() (28)阅读下列程序段,则程序的输出结果为 #include &stdio.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(&%d\n&,k); A)3B)5C)6D)8(29)在 16 位 IBM-PC 机上使用 C 语言,若有如下定义 struct data { } 则结构变量 b 占用内存的字节数是 A)1 B)2 C)7 D)11 (30)有以下程序 #include&stdio.h& main() {FILE * int i,a[6]={l,2,3,4,5,6}; fp=fopen(&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&6;i++)printf(&%d,&,a[i]); } 程序运行后的输出结果是 A)4,5,6,4,5,6, (31)有以下程序 #include &stdio.h& main() { int s[12]={1,2,3,4,4,3,2,1,1,1,2,3},c[5]={0},i; B)1,2,3,4,5,6, C)4,5,6,1,2,3, D)6,5,4,3,2,1,for(i=0;i&12;i++) c[s[i]]++; for(i=1;i&5;i++) printf(&%d&,c[i]); printf(&\n&); } 程序的运行结果是 A)1 2 3 4 (32)有以下程序 #include &stdio.h& void fun(int { int t,i,j; *a,int n)/*fun 函数的功能是将 a 所指数组元素从大到小排序*/ B)2 3 4 4 C)4 3 3 2 D)1 1 2 3for(i=0;i&n-1;j++) for(j=i+1;j&n;j++) if(a[i]&a[j]) { t=a[i];a[i]=a[j];a[j]=t;} } main() { int c[10]={1,2,3,4,5,6,7,8,9,0},i;fun(c+4,6); for(i=0;i&10;i++) printf(&%d,&,c[i]); printf(&\n&); } 程序的运行结果是 A)1,2,3,4,5,6,7,8,9,0, (33)下面程序的输出结果是 #include&stdio.h& #include&string.h& main() { char *p1=&abc&,*p2=&ABC&,str[50]= &xyz&; B)0,9,8,7,6,5,1,2,3,4, C)0,9,8,7,6,5,4,3,2,1, D)1,2,3,4,9,8,7,6,5,0,strcpy(str+2,strcat(p1,p2)); printf(&%s\n&,str);} A)xyzabcABC B)zabcABC C)xyabcABC D)yzabcABC (34)以下函数返回 a 所指数组中最小的值所在的下标值 fun(int *a, int n) { int i,j=0,p; p=j; for(i=j;i&n;i++) if(a[i]&a[p]); ________; return(p);} 在横线处应填入的是 A)i=p B)a[p]=a[i] C)p=j D)p=i (35)下列程序的运行结果为 #include&stdio.h& void abc(char*str) { int a,b;for(a=b=0;str[a]!='\0';a++) if(str[a]!='c') str[b++]=str[a]; str[b]='\0';} void main() { char str[]=&abcdef&;abc(str); printf(&str[]=%s&,str); } A)str[]=abdef (36)有以下程序 #include &stdio.h& #include &string.h& typedef void { struct{ a) char name[9]; float score[2]; }STU; B)str[]=abcdef C)str[]=a D)str[]=abf(STUSTU b={&Zhao&,′m′,85?0,90?0};strcpy(a.name,b.name); a.sex=b. for(i=0;i&2;i++) } main() { STU c={&Qian&,′f′,95.0,92.0}; a.score[i]=b.score[i]; f(c); printf(&%s,%c,%2.0f,%2.0f\n&,c.name,c.sex,c.score[0],c.score[1]); } 程序的运行结果是 A)Qian,f,95,92 (37)有以下程序 #include &stdio.h& main() { FILE ?* int a[10]={1,2,3},i,n; B)Qian,m,85,90 C)Zhao,f,95,92 D)Zhao,m,85,90fp=fopen(&d1.dat&,&w&); for(i=0;i&3;i++) fprintf(fp,&\n&); fclose(fp); fp=fopen(&d1.dat&,&r&); fscanf(fp,&%d&,&n); fclose(fp); printf(&%d\n&,n); } 程序的运行结果是 A)12300 B)123 C)1 D)321 (38)已知 int a=1,b=3 则 a^b 的值为 A)3 B)1 C)2 D)4 (39)阅读下列程序,则运行结果为 #include &stdio.h& fun() { x++;} main() { int i,x; static int x=5; fprintf(fp,&%d&,a[i]);for(i=0;i&3;i++) x=fun(); printf(&%d\n&,x);} A)5 B)6 C)7 D)8 (40)有以下程序 #include &stdio.h& void fun(char *t,char *s) { while(*t!=0) t++;while((*t++=*s++)!=0); } main() { char ss[10]=&acc&,aa[10]=&bbxxyy&; fun(ss,aa); } printf(&%s,%s\n&,ss,aa); 程序的运行结果是 A)accxyy,bbxxyy 二、填空题 请将每一个空的正确答案写在答题卡序号的横线上,答在试卷上不给分。 (1)需求分析的最终结果是产生 【1】 。 【2】 【3】 【4】 两部分组成。 。 个叶子结点。 (2)为了便于对照检查,测试用例应由输入数据和预期的 (3)数据结构分为逻辑结构与存储结构,线性链表属于 (4)某二叉树中度为 2 的结点有 18 个,则该二叉树中有 (5) 【5】 是数据库设计的核心。 a=1,b;(此处 c 的初值为空格字符),执行 b=!c&&a;后 b 的值为? 【6】 ? 。 【7】 。 (6)已有定义:char c=′ ′;int B)acc,bbxxyy C)accxxyy,bbxxyy D)accbbxxyy,bbxxyy(7)设变量已正确定义为整型,则表达式 n=i=2,++i,i++的值为(8)下面程序的功能是:计算 1 10 之间的奇数之和与偶数之和,请填空。 #include&stdio.h& main() { int a,b,c,I; a=c=0; for(I=0;I&=10;I+=2) {a+=I; 【8】 ; c+=b; } printf(&偶数之和=%d\n&,a); printf(&奇数之和=%d\n&,c-11);} (9)以下函数 rotate 的功能是:将 a 所指 N 行 N 列的二维数组中的最后一行放到 b 所指二维数组的第 0 列 中,把 a 所指二维数组中的第 0 行放到 b 所指二维数组的最后一列中,b 所指二维数组中其他数据不变。 #define N 4 a[][N],int b[][N])void rotade(int { int I,j;for(I=0;I&N;I++) { b[I][N-1]= 【9】 ; 【10】 【11】 =a[N-1][I]; } } 。 (10)以下程序的输出结果是 #include &stdio.h& void { int swap(int ?*t; a=b; b=t; ?*a, int ?*b)t=a; }main() { int i=3,j=5,?*p=&i,?*q=&j; printf(&%d %d\n&,*p,*q); 【12】 。swap(p,q); }(11)下面程序的运行结果是 #include&stdio.h& #define SIZE 12 main() { char s[SIZE]; int I;for(I=0;I&SIZE;I++) sub(s,7,SIZE-1); for(I=0;I&SIZE;I++) printf(&\n&);} sub(char*a,int t1,int t2) { while (t1&t2) { ch=*(a+t1); *(a+t1)=*(a+t2); *(a+t2)= t1++;t2--; } } (12)以下程序的输出结果是 #include &stdio.h& main() { int a[5]={2,4,6,8,10},?*p; p++; 【13】 printf(&%c&,s[I]);s[I]=′A′+I+321;。p=a;printf(&%d&,?*p); } (13)设有定义&struct {} abc, *p_abc=&&,则对结构体成员 a 的引用方法可以是 abc.a 和 p_abc 【14】 a。 【15】 。 (14)以下程序的运行结果是 #include &stdio.h& main() { FILE * int a[10]={1,2,3,0,0},i;fp=fopen(&d2.dat&,&wb&); fwtite(a,sizeof(int),5,fp); fwrite(a,sizeof(int),5,fp); fclose(fp); fp=fopen(&d2.dat&,&rb&); fread(a,sizeof(int),10,fp); fclose(fp); for(i=0;i&10;i++)printf(&%d&,a[i]); } 一、选择题 (1)D 【解析】 软件是程序、数据与相关文档的集合,相对于计算机硬件而言,软件是逻辑产品而不是物 【解析】 确认测试的任务是验证软件的功能和性能,以及其他特性是否满足需求规格说明中确定的 【解析】 对象的基本特点:标识惟一性、分类性、多态性、封装性和模块独立性。 【解析】 滥用 goto 语句将使程序流程无规律,可读性差,因此 A)不选;注解行有利于对程序的理解, 【解析】 程序执行的效率与很多因素有关,如数据的存储结构、程序所处理的数据量、程序所采用 理产品,是计算机的无形部分。 (2)A 各种需求;集成测试的主要目的是发现与接口有关的错误。 (3)C (4)D不应减少或取消,B)也不选;程序的长短要依照实际情况而论,而不是越短越好,C)也不选。 (5)A 的算法等。顺序存储结构在数据插入和删除操作上的效率比链式存储结构的效率低。 (6)C【解析】 数据结构概念一般包括数据的逻辑结构、存储结构及数据上的运算集合等。数据的逻辑 【解析】 顺序存储结构中,数据元素存放在一组地址连续的存储单元中,每个数据元素地址可通过结构只抽象地反映数据元素之间的逻辑关系,而不管它在计算机中的存储形式。 (7)B 公式 LOC(ai)=LOC(a1)+(i-1)L 计算得到,从而实现了随机存取。对于链式存储结构,要对某结点进行存取,都 得从链的头指针指向的结点开始,这是一种顺序存取的存储结构。 (8)C 【解析】 树是 N(N&0)个结点的有限集合,当?N=0?, 时称为空树,对于空树没有根结点,即根结点的 【解析】 数据库(DataBase,简称 DB)是数据的集合,它具有统一的结构形式并存放于统一的存储介 【解析】 数据库系统(Database System,简称 DBS),包括数据库(Database,简称 DB)和数据库管理系 【解析】 选项 D)为两条语句。 【解析】 C 语言规定的标识符只能由字母、数字和下划线 3 种字符组成,第一个字符必须为字母 个数为 0,对于非空树有且只有一个根结点,所以树的根结点数目为 0 或 1。 (9)C 质内,是多种应用数据的集成,可被各个应用程序所共享。数据库中的数据具有&集成&、&共享&的特点。 (10)B 统(Database Management System,简称 DBMS)。 (11)D (12)C或下划线,并且不能使用 C 语言中的关键字作为标识符。选项 C)中 goto 和 int 是关键字,b-a 中'-'不是组成标 识符的 3 种字符之一;选项 D)中 int 是关键字,所以,均是不合法用户标识符的选项是 C)。 (13)B 【解析】 在 C 语言程序中,用单引号把一个字符或反斜线后跟一个特定的字符括起来表示一个字 【解析】 求余运算符&%&两边的运算对象必须是整型,而选项 B)和 D)中 &%&两边的运算对象有浮 符常量。选项 A)、C)和 D)为正确的字符常量,而选项 B)是用双引号括起来的字符,表示一个字符串常量。 (14)C 点整数据,所以选项 B)和 D)是错误的表达式。 在选项 A)中赋值表达式的两边出现相同的变量 x,也是错误的。 选项 C)是一个逗号表达式,所以正确答案为 C)。 (15)B 【解析】 选项 A)中包含一个不合法的运算符&:=&;选项 C)应改为(int)18.5%3;选项 D)可理解为两 个表达式:a+7=c+b 和 a=a+7,其中第一个是错的,因为 C 语言规定赋值号的左边只能是单个变量,不能是表达 式或常量等。因此,正确答案是选项 B),它实际上相当于 a=(b=c+2),进而可分解为两个表达式:b=c+2 和 a=b。 (16)B 【解析】 由于在 main()函数中,变量 i=4,所以就调用 fun(4),则输出&m=4 k=4&。然后变量 k 增 1 等 【解析】 在本题中,选项 B)实际是先计算关系表达式&'A'&=c&的值是 0 还是 1,再比较该值与字符'Z' 【解析】 本题考查逻辑与运算的运算规则。其规则是:当运算符前后两个条件表达式都满足时, 于 5,变量 i 增 1 等于 5,所以 main()函数的&printf(&i=%d k=%d\n&,i,k);&语句输出&i=5 k=5& (17)B 之间的大小关系,显然不能实现题目所要求的功能,而选项 A)、C)、D)都可以。 (18)B 其最终结果才为真。当发现第一个表达式的值为假,计算机将不再执行后面表达式的运算。 本题中,由于前一个表达式的值为&假&,所以,后面的表达式不再进行运算,因而 n 的值保持不变,仍为 2。 (19)B 【解析】 两个 if 语句的判断条件都不满足,程序只执行了 c=a 这条语句,所以变量 c 的值等于 3, 【解析】 C 语言中,switch 语句专用于实现多分支结构程序,其特点是各分支清晰而直观。switch 变量 b 的值没有变化,程序输出的结果为 3,5,3。 (20)C 后面括号中可以是任何表达式,取其整数部分与各常量表达式进行比较。 常量表达式中不能出现变量,且类型 必须是整型、字符型或枚举型,各常量表达式各不相同。 (21)C 【解析】 本题考察变量的自加&++&和自减&--&问题。当 y 的值为 9、6 或 3 时,if 语句的条件成立, 【解析】 do while 语句的一般形式为:do 循环体语句 while(表达式);,其中循环体语句可以是复合 执行输出语句,输出表达式--y 的值,y 的自减要先于输出语句执行,故输出结果为 8 5 2。 (22)C 型语句,但必须用花括号括起来。while 后必须要有分号作为语句的结束,在 do-while 循环中,不可以省略 while。 (23)D 【解析】 在程序中指针变量 p 初始指向 a[3],执行 p 减 1 后,p 指向 a[2],语句 y=*p 的作用是把 a[2] 【解析】 二维数组的初始化有以下几种形式:① 分行进行初始化;② 不分行进行初始化;③ 部分数组 的值赋给变量 y,所以输出为 y=3。 (24)B 元素进行初始化;④ 省略第一维的定义,不省略第二维的定义。选项 B)等号右边分了 3 行,大于等号左边数组 的行数 2。 (25)D 【解析】 C 语言中操作一个字符串常量的方法有:① 将字符串常量存放在一个字符数组之中;② 用 字符指针指向字符串, 然后通过字符指针来访问字符串存储区域。 当字符串常量在表达式中出现时, 根据数 组的类型转换规则, 将其转换成字符指针。 本题 D)项中错误的关键是对数组初始化时,可以在变量定义时整体赋初值,但不能在赋值语句中整体赋值。 (26)D 【解析】 C 语言中数组下标是从 0 开始的,所以二维数组 a[2][3]的第一维下标取值为 0、1;第二维 【解析】 scanf()语句用&空格&区别不同的字符串;getc()与 getchar()语句不能用于字符串的读入。 【解析】 带参数的宏定义命令行形式如下:#define 宏名(形参表) 替换文本。首先进行 M 的宏替 【解析】 结构体变量所占用内存的字节数是其所有成员所占用内存字节数之和。本题中整型变 的下标取值为 0、1、2,因而选项 A)、B)、C)都是错误的,选项 D)表示数组元素 a[0][0]。 (27)B (28)A换,之后再进行 N 的宏替换,替换后的表达式为 (a)*(b)/(c)。 (29)D 量 i 所占用的内存是 2 字节,字符型变量 ch 所占用的内存是 1 字节,双精度型变量 f 所占用的内存是 8 字节, 三者相加即可。 (30)A 【解析】 首先利用 fwrite 函数将数组 a 中的数据写到文件中,接着 fseek 函数的功能是读文件的位 置,指针从文件头向后移动 3 个 int 型数据,这时文件位置指针指向的是文件中的第 4 个 int 数据&4&,然后 fread 函数将文件 fp 中的后 3 个数据 4,5,6 读到数组 a 中,这样就覆盖了数组中原来的前 3 项数据。最后数组中的 数据就成了{4,5,6,4,5,6}。 (31)C 【解析】 在 for(i=0;i&12;i++) c[s[i]]++中,数组元素 s[i]的值作为数组 c 的下标,当退出循环时,数组 【解析】 在本题中,主函数在调用 fun()函数进行排序时,传递的参数是 c+4 和 6,fun()函数实现的功 c 的 4 个元素的值分别为 4、3、3、2。 (32)D 能是将数组 c 的第 5 个元素开始的 6 个元素依次进行从大到小的顺序排列。排序之后,数组 c 的内容变为 {1,2,3,4,9,8,7,6,5,0}。 (33)C 【解析】 本题考查的重点是拷贝字符串──使用 strcpy()函数,该函数的调用方式是:strcpy(字符数 组, 字符串),其中&字符串&可以是字符串常量,也可以是字符数组。函数的功能是:将&字符串&完整地复制到& 字符数组&中,字符数组中原有的内容被覆盖。 使用该函数时注意:① 字符数组必须定义得足够大,以便容纳复制过来的字符串。复制时,连同结束标志'\0'一 起复制;② 不能用赋值运算符&=&将一个字符串直接赋值给一个字符数组,只能用 strcpy( )函数处理。 另外,本题还考查连接字符串的 strcat()函数,其调用方式是:strcat(字符数组, 字符串)。 功能是把&字符串&连接到&字符数组&中的字符串尾端,并存储于&字符数组&中。 &字符数组&中原来的结束标志, 被&字符串&的第一个字符覆盖,而&字符串&在操作中未被修改。 使用该函数时注意:①由于没有边界检查,编程者要注意保证&字符数组&定义得足够大,以便容纳连接后的目 标字符串;否则,会因长度不够而产生问题;② 连接前两个字符串都有结束标志'\0',连接后&字符数组&中存储的 字符串的结束标志'\0'被舍弃,只在目标串的最后保留一个'\0'。 (34)D 【解析】 该程序先判断 a[i]&a[p],如果条件为真,则 a[i]比当前设定的最小值小(p 保留的当前最小 【解析】 本题考查了用字符指针引用字符数组中的字符及对字符的操作。函数 abc()的 for 语句 元素的下标),那么将 i 赋给 p,即将比较过的最小元素下标保留在 p 中,作为下面判断的标准。 (35)A 执行过程是:从字符指针 str 所指向的字符数组的第一个元素开始,逐一判断字符是否为'c',若不是就执行一次 数组元素的赋值过程,若字符为'c'就不执行。 (36)A c 的值。 (37)B 【解析】 在函数中首先把整型数组 a[10]中的每个元素写入文件 d1.dat 中,然后再次打开这个文件, 【解析】 ^是按位异或运算,如果对应位不同则结果为 1,相同则为 0。 把文件 d1.dat 中的内容读入到整型变量 n 中,最后输出变量 n 的值。 (38)C 【解析】 本题考查的是函数调用时的参数传递问题。程序在调用函数 f 时,传给函数 f 的参数只 是结构变量 c 在栈中的一个拷贝,函数 f 的所有操作只是针对这个数据拷贝进行的修改,这些都不会影响变量 (39)D【解析】 在整个程序运行期间,静态局部变量在内存的静态存储区中占据着永久的存储单元,即使退出函数以后,下次再进入该函数时,静态局部变量仍使用原来的存储单元,静态局部变量的初值是在编译的 时候赋予的,在程序执行期间不再赋予初值。 本题由于连续三次调用函数 fun(),三次对静态变量 x 进行操作,x 的值应依次为 6,7,8。 (40)D 【解析】 本题中 fun 函数实现了字符串函数 strcat 的功能,将字符串 aa 连接到字符串 ss 的末尾。 调用 fun 函数时,形参 t 和 s 分别指向了字符串 ss 和 aa,然后通过一个 while 循环使 t 指向字符串 ss 的结束符 的位置,第二个 while 循环将字符串 aa 中的字符(包括结束符'\0')逐个复制到字符串 ss 的末尾处。 二、选择题 (1)【1】 需求规格说明书 性和可追踪性等。 (2)【2】 输出结果 (3)【3】 存储结构 【解析】 测试用例(Text Case)是为测试设计的数据。测试用例由测试输入数据和与 【解析】 数据的逻辑结构是指反映数据元素之间逻辑关系的数据结构;数据的存储 之对应的预期输出结果两部分组成。 结构是指数据的逻辑结构在计算机存储空间中的存放形式。在数据的存储结构中,不仅要存放各数据元素的 信息,还需要存放各数据元素之间的前后件关系的信息。 (4)【4】 19 【解析】 在任意一棵二叉树中,度为 0 的结点(即叶子结点)总是比度为 2 的结点多一个。 【解析】 数据模型是对客观事物及联系的数据描述,它反映了实体内部及实体与实 (5)【5】 数据模型 【解析】 软件需求规格说明书是需求分析阶段的最后成果,是软件开发中的 重要文档之一。需求规格说明书包括正确性、无歧义性、完整性、可验证性、一致性、可理解性、可修改体之间的联系。因此,数据模型是数据库设计的核心。 (6)【6】 1 然为 0。 (7)【7】 3 【解析】 本题考查的是 C 语言逗号表达式的相关知识。程序在计算逗号表达式时,从左到右 计算由逗号分隔各表达式的值,整个逗号表达式的值等于其中最后一个表达式的值。本题中,首先 i 被赋值为 2,再自加 1,最后 i++的值计算为 3。 (8)【8】 b=I+1 【解析】 本题考查了 for 循环语句的执行过程。i+=2 是修正表达式,执行一次循环体后 i 的值就增加 2,i 的初始值为 0,每次加 2 后的和累加至 a,所以 a 的值就是 1 10 之间的偶数之和; b 的值是 1 11 之间的奇数和,但在输出 b 值时,c 去掉多加的 11,即为 1 10 之间的奇数之和。 (9)【9】 a[0][I] 【10】 b[I][0] 二维数组中的第 0 列。 (10)【11】 3 5 【解析】 函数 swap(int *a,int *b)的功能是实现*a 和?*b? 中两个数据的交换,在主函数 中调用 swap(p,q)后,参形指针变量 a 和 b 分别指向 i 和 j,在 swap(int *a,int *b)执行完后,指针变量 a 和 b 分别 指向 j 和 i,而指针变量 p,q 所指向变量的值没有发生变化,所以输出结果为 3 5。 (11)【12】 a b c d e f g l k j I h 【解析】 本题主要考查了字符变量可参与的运算。因为字符在计算机中 是以 ASCII 码的形式存放的,所以字符变量可看作整型变量来处理,如参与算术运算等,某字符的大写字母的 ASCII 码值比它对应的小写字母 ASCII 码值小 32。 (12)【13】 4 (13)【14】 -& 【解析】 在主函数中,语句 p=a;p++使用指针 p 指向数组 a[1],所以输出结果为 4。 【解析】 若结构体变量 abc 有成员 a,并有指针 p_abc 指向结构变量 abc,则引用变量 abc 【解析】 本题考查文件读写函数 fread 和 fwrite 的用法。fwrite 函数将数 【解析】 b[i][N-1]= a[0][i]实现把 a 所指二维数组中的第 0 行放到 b 所 指二维数组的最后一列中,?b[I][0]=a[N -1][I] 实现将 a 所指 N 行 N 列的二维数组中的最后一行放到 b 所指 【解析】 字符空格的 ASCII 码不为 0,所以本题中表达式?!c? 的值为 0, b=0&&1 的结果显成员 a 的标记形式有 abc.a 和 p_abc-&a。 (14)【15】 1,2,3,0,0,1,2,3,0,0, 组 a 的前 5 个元素输出到文件 fp 中两次,共 10 个字节,再调用 fread 函数从文件 fp 中读取这 10 个字节的数 据到数组 a 中,此时数组 a 的内容就变为{1,2,3,0,0,1,2,3,0,0},最后的输出结果为&1,2,3,0,0,1,2,3,0,0,&。第四套 一、选择题 在下列各题的 A) 、B) 、C) 、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应 位置上,答在试卷上不得分。 (1)软件生命周期中花费费用最多的阶段是 A)详细设计 B)软件编码 C)软件测试 D)软件维护 (2)为了提高测试的效率,应该 A)随机选取测试数据 试计划 B)取一切可能的输入数据作为测试数据 C)在完成编码以后制定软件的测D)集中对付那些错误群集的程序(3)以下不是面向对象思想中的主要特征的是 A)多态 B)继承 C)封装 D)垃圾回收 (4)下列叙述中,不符合良好程序设计风格要求的是 A)程序的效率第一,清晰第二 数据前要有提示信息 (5)软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指 A)模块间的关系 B)系统结构部件转换成软件的过程描述 C)软件层次结构 D)软件开发过程 (6)数据处理的最小单位是 A)数据 B)数据元素 C)数据项 D)数据结构 (7)假设线性表的长度为 n,则在最坏情况下,冒泡排序需要的比较次数为 A)log2n B)n2 C)O(n1..5) D)n(n-1)/2 (8)在深度为 5 的满二叉树中,叶子结点的个数为 A)32 B)31 C)16 D)15 (9)数据库系统的核心是 A)数据库 B)数据库管理系统 C)模拟模型 D)软件工程 (10)一个关系中属性个数为 1 时,称此关系为 A)对应关系 B)单一关系 C)一元关系 D)二元关系 (11)下面各选项中,均是 C 语言合法标识符的选项组是 A)33 we auto B)_23 me _3ew C)_43 3e_ else D)ER -DF 32 (12)可在 C 程序中用作用户标识符的一组标识符是 A)and _2007 B)Date y-m-d C)Hi Dr.Tom D)case Bigl B)程序的可读性好 C)程序中要有必要的注释 D)输入(13)以下对 C 语言函数的有关描述中,正确的是 A)在 C 语言中调用函数时,只能把实参的值传给形参,形参的值不能传送给实参 B)C 函数既可以嵌套定义又可以递归调用 C)函数必须有返回值,否则不能使用函数 D)函数必须有返回值,返回值类型不定 (14)若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是 A)函数的实参和其对应的形参共占同一存储单元 C)同名的实参和形参占同一存储单元 B)形参只是形式上的存在,不占用具体存储单元D)函数的形参和实参分别占用不同的存储单元(15)现有定义,则表达式 a/b+c-k 值的类型为: A)int B)double C)float D)char (16)以下关于 long、int 和 short 类型数据占用内存大小的叙述中正确的是 A)均占 4 个字节 C)由用户自己定义 (17)有以下程序段 B)根据数据的大小来决定所占内存的字节数 D)由 C 语言编译系统决定 intj;floaty;charname[50];scanf(&%2d%f%s&,&j,&y,name); 当执行上述程序段,从键盘上输入 abc 后,y 的值为 A)55566.0 B)566.0 C)7777.0 D) (18)若变量已正确定义,有以下程序段 i=0; do printf(&%d,&,i);while(i++); printf(&%d\n&,i); 其输出结果是 A)0,0 B)0,1 C)1,1 D)程序进入无限循环 (19)下列程序的运行结果是 #include &stdio.h& main() { int x=-9,y=5,z=8;if(x&y) if(y&0)z=0; else z+=1; printf(&%d\n&,z);} A)6 B)7 C)8 D)9 (20)若程序执行时的输入数据是&2473&,则下述程序的输出结果是 #include&stdio.h& void main() { while((cs=getchar())!=; '\n') {switch(cs-'2') { case 0case 1: putchar(cs+4); case 2: putchar(cs+4); case 3: putchar(cs+3); default: putchar(cs+2); } } } A)668977 B)668966 C)6677877 D)6688766 (21)以下程序的输出结果是 main() { int a,i;a=0;for(i=1;i&5;i++) { { switch(i) case 0:case 3:a+=2; case 1: case 2:a+=3; default:a+=5; } }printf(&%d\n&,a);} A)31 B)13 C)10 D)20 (22)现有如下程序段 #include &stdio.h& main() { int k[30]={12,324,45,6,768,98,21,34,453,456};int count=0,i=0; while(k[i]) { if(k[i]%2==0||k[i]%5==0)count++;i++; } printf(&%d,%d\n&,count,i);} 则程序段的输出结果为 A)7,8 (23)若有以下程序 #include &stdio.h& int a[]={2,4,6,8}; main() { B)8,8 C)7,10 D)8,10int *p=a; for(i=0;i&4;i++)a[i]=*p; printf(&%d\n&,a[2]);} 上面程序的输出结果是 A)6 B)8 C)4 D)2 (24)有以下程序 #include &stdio.h& main() { int i,j,m=55; for(i=1;i&=3;i++) for(j=3;j&=i;j++)m=m%j; printf(&%d\n&,m); } 程序的运行结果是 A)0 后,输出结果是 A)A,B B)A,68 C)65,66 D)65,68 (26)下列程序是用来判断数组中特定元素的位置所在的。 #include &conio.h& #include &stdio.h& int fun(int *s, int t, int *k) { *k=0; for(i=0;i&t;i++) if(s[*k]&s[i])*k=i; B)1 C)2 D)3 (25) 已知字符′A′的 ASCII 码值是 65,字符变量 cl 的值是′A′,c2 的值是′D′。 执行语句 printf(&%d,%d&,c1,c2-2); return s[*k]; } main() { int a[10]={ 876,675,896,101,301,401,980,431,451,777},k; fun(a, 10, &k); printf(&%d, %d\n&,k,a[k]);} 如果输入如下整数:876 675 896 101 301 401 980 431 451 777 则输出结果为 A)7,431 则程序输出的结果是 #include &stdio.h& main(argc,argv)char *argv[]; { B)6 C)980 D)6,980 (27)下面程序的文件名为 t.exe,在 DOS 下输入的命令行参数为:t to meet me&回车&printf(&%d\n&,argc);} A)3 B)4 C)2 D)以上答案都不正确 (28)有如下程序 int a[10]={1,2,3,4,5,6,7,8,9,10}; int *p=&a[3],b;b=p[5]; 则 b 的值是 A)5 B)6 C)9 D)8 (29)以下叙述中错误的是 A)改变函数形参的值,不会改变对应实参的值 C)可以给指针变量赋一个整数作为地址值 量赋 NULL (30)下面程序的输出结果是 #include&st

我要回帖

更多关于 c语言程序 的文章

 

随机推荐