[计算机类试卷]国家二级(C语言)机试模拟试卷96及答案与解析.doc

上传人:brainfellow396 文档编号:503224 上传时间:2018-11-29 格式:DOC 页数:28 大小:75.50KB
下载 相关 举报
[计算机类试卷]国家二级(C语言)机试模拟试卷96及答案与解析.doc_第1页
第1页 / 共28页
[计算机类试卷]国家二级(C语言)机试模拟试卷96及答案与解析.doc_第2页
第2页 / 共28页
[计算机类试卷]国家二级(C语言)机试模拟试卷96及答案与解析.doc_第3页
第3页 / 共28页
[计算机类试卷]国家二级(C语言)机试模拟试卷96及答案与解析.doc_第4页
第4页 / 共28页
[计算机类试卷]国家二级(C语言)机试模拟试卷96及答案与解析.doc_第5页
第5页 / 共28页
点击查看更多>>
资源描述

1、国家二级( C语言)机试模拟试卷 96及答案与解析 一、选择题 1 程序流程图中带有箭头的线段表示的是 ( )。 ( A)图元关系 ( B)数据流 ( C)控制流 ( D)调用关系 2 结构化程序设计的基本原则不包括 ( )。 ( A)多态性 ( B)自顶向下 ( C)模块化 ( D)逐步求精 3 软件设计中模块划分应遵循的准则是 ( )。 ( A)低内聚低耦合 ( B)高内聚低耦合 ( C)低内聚高耦合 ( D)高内聚高耦合 4 在软件开发中,需求分析阶段产生的主要文档是 ( )。 ( A) 可行性分析报告 ( B)软件需求规格说明书 ( C)慨要设计说明书 ( D)集成测试计划 5 算法的

2、有穷性是指 ( )。 ( A)算法程序的运行时间是有限的 ( B)算法程序所处理的数据量是有限的 ( C)算法程序的长度是有限的 ( D)算法只能被有限的用户使用 6 对长度为 n的线性表排序,在最坏情况下,比较次数不是 n(n-1) 2的排序方法是 ( )。 ( A)快速排序 ( B)冒泡排序 ( C)直接插入排序 ( D)堆排序 7 下列关于栈的叙述正确的是 ( )。 ( A)栈按 “先进先出 ”组织 数据 ( B)栈按 “先进后出 ”组织数据 ( C)只能在栈底插入数据 ( D)不能删除数据 8 在数据库设计中,将 ER图转换成关系数据模型的过程属于 ( )。 ( A)需求分析阶段 (

3、B)概念设计阶段 ( C)逻辑设计阶段 ( D)物理设计阶段 9 有三个关系 R、 S和 T如下:由关系 R和 S通过运算得到关系 T,则所使用的运算为 ( )。 ( A)并 ( B)自然连接 ( C)笛卡尔积 ( D)交 10 设有表示学生选课的三张表,学生 S(学号,姓名,性别,年龄,身份证号 ),课程 C(课号,课名 ),选课 SC(学号,课号,成绩 ),则表 SC的关键字 (键或码 )为( )。 ( A)课号,成绩 ( B)学号,成绩 ( C)学号,课号 ( D)学号,姓名,成绩 11 以下叙述中错误的是 ( )。 ( A) C语言中的每条可执行语句和非执行语句最终鄙将被转换成二进制的

4、机器指令 ( B) C程序经过编译、连接步骤之后才能形成一个真正可执行的二进制机器指令文件 ( C)用 C语言编写的程序称为源程序,它以 ASCII代码形式存放在一个文本文件中 ( D) C语言源程序经编泽后生成后缀为 obj的目标程序 12 以下选项中,合 法的一组 C语言数值常量是 ( )。 ( A) 12 0Xa234 5e0 ( B) 028 5e-3 -0xf ( C) 177 4e1 5 0abc ( D) 0x8A 10 000 3 e5 13 以下选项中不合法的标识符是 ( )。 ( A) &a ( B) FOR ( C) print ( D) _00 14 若有代数式 (其中

5、 e仅代表自然对数的底数,不是变量 ),则以下能够正确表示该代数式的 C语言表达式是 ( )。 ( A) sqn(fabs(pow(n, x)+exp(x) ( B) sqrt(fabs(pow(n, x)+pow(x, e) ( C) sqrt(abs(n x+e x) ( D) sqrt(fabs(pow(x, n)+exp(x) 15 若有定义: double a=22; int i=0, k=18;,则不符合 C语言规定的赋值语句是( )。 ( A) i=(a+k) =(i+k); ( B) i=a 11; ( C) a=a+, i+; ( D) i=!a; 16 有以下程序: #in

6、lude stdio h main() int s, t, A=10; double B=6: s=sizeof(A); t=sizeof(B); printf(“ d, d n“, s, t); 在 VC6 0平台上编译运行,程序运行后的输出结果是 ( )。 ( A) 10, 6 ( B) 4, 4 ( C) 2, 4 ( D) 4, 8 17 有以下程序: #include stdio h main() char a, b, c, d; scanf(“ c c“, &a, &b); c=getchar(); d=getchar(); printf(“ c c c c n“, a, b, c

7、, d); 当执行程序时,按下列方式输入 数据 (从第 1列开始, CR代表回车,注意:回车也是一个字符 ) 12 CR 34 CR 则输出结果是 ( )。 ( A) 12 34 ( B) 12 ( C) 1234 ( D) 12 18 以下关于逻辑运算符两侧运算对象的叙述中正确的是 ( )。 ( A)可以是任意合法的表达式 ( B)只能是整数 0或非 0整数 ( C)可以是结构体类型的数据 ( D)只能是整数 0或 1 19 有以下程序: #include stdio h main() int a=0, h=0, c=0, d=0; if(a=1)b=1; c=2; else d=3: pr

8、intf(“ d, d, d, d n“, a, b, c, d); 程序运行后的输出结果是 ( )。 ( A) 1, 1, 2, 0 ( B) 0, 0, 0, 3 ( C)编译有错 ( D) 0, 1, 2, 0 20 有以下程序: #inelude stdio h main() int x=1, v=0, a=0, b=0; switch(x) case1: switch(y) case0: a+; break; case1: b+; break; case2: a+; b+; break; ease3: a+; b+; printf(“a= d, b= d n“, a, b); 程序运

9、行后的输出结果是 ( )。 ( A) a=2, b=2 ( B) a=2, b=1 ( C) a=1, b=1 ( D) a=1, b=0 21 以下程序段中的变量已正确定义: for(i=0; i 4; i+, i+) for(k=1; k 3; k+); printf(“*“); 程序段的输出结果是 ( )。 ( A) * ( B) * ( C) * ( D) * 22 有以下程序段: #include stdio h int i, n; for(i=0; 0; i 8; i+) n=rand() 5; switch(n) ease1: ease3: printf(“ d n“, n);

10、break; ease2: ease4: printf(“ d n“, n); continue; case0: exit(0); printf(“ d n“, n); 以下关于程序段执行情况的叙述,正确的是 ( )。 ( A) for循环语句固定执行 8次 ( B)当产生的随机数 n为 4时结束循环操作 ( C)当产生的随机数 n为 1和 2时不做任何操作 ( D)当产生的随机数 n为 0时结束程序运行 23 有以下程序: #include stdio h int f(int x); main() int n=l, m; m=f(f(f(n); printf(“ d n“, m); int

11、f(int x) return x*2; 程序运行后的输出结果是 ( )。 ( A) 8 ( B) 2 ( C) 4 ( D) 1 24 以下叙述中错误的是 ( )。 ( A)可以给指针变量赋一个整数作为地址值 ( B)函数可以返回地址值 ( C)改变 函数形参的值,不会改变对应实参的值 ( D)当在程序的开头包含头文件 stdio h时,可以给指针变量赋 NULL 25 设已有定义: float x;,则以下对指针变量 p进行定义且赋初值的语句中正确的是 ( )。 ( A) int*p=(float)x; ( B) float*p=&x; ( C) float p=&x; ( D) floa

12、t*p=1024; 26 以下数组定义中错误的是 ( )。 ( A) int x23=1, 2, 3, 4, 5, 6; ( B) int x3=0; ( C) int x3=1, 2, 3, 4, 5, 6; ( D) int x23=1, 2, 3, 4, 5, 6; 27 有以下程序: #include stdio h void fun(int a, int n) int i, t; for(i=0; i n 2; i+)t=ai; ai=an-1-i; an-1-i=t; main() int k10=1, 2, 3, 4, 5, 6, 7, 8, 9, 10, i; fun(k, 5

13、); for(i=2; i 8; i+)printf(“ d“, ki); printf(“ n“); 程序运行后的输出结果是 ( )。 ( A) 321678 ( B) 876543 ( C) 1098765 ( D) 345678 28 有以下程序: #include stdio h #define N4 void fun(int aN, int b) int i; for(i=0; i N; i+)bi=aii-aiN-1-i; main() int xNN=1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,16, yN, i; fun(

14、x, y); for(i=0; i N; i+)printf(“ d, “, yi); printf(“ n“); 程序运行后的输出结果是 ( )。 ( A) -3, -1, 1, 3, ( B) -12, -3, 0, 0, ( C) 0, 1, 2, 3, ( D) -3, -3, -3, -3, 29 设有定义: char s81; int i=0;,以下不能将一行 (不超过 80个字符 )带有空格的字符串正确读入的语句或语句组是 ( )。 ( A) gets(s); ( B) while(si+=getehar()!= n); si= 0; ( C) seanf(“ s“, s); (

15、 D) doscanf(“ c“, &si); while(si+!= n); si= 0; 30 设有定义; char p=1, 2, 3, *q=p;,以下不能计算出一个 char型数据所占字节数的表达式是 ( )。 ( A) sizeof(p) ( B) sizeof(char) ( C) sizeof(*q) ( D) sizeof(p0) 31 有以下程序: #include stdio h #include string h main() char sfr20=“One*World“, “One*Dream!“, *p=str1; printf(“ d, “, strlen(p);

16、 printf(“ s n“, p); 程序运行后的输出结果是 ( )。 ( A) 10, One*Dream! ( B) 9, One*Dream! ( C) 9, One*World ( D) 10, One*World 32 有以下程 序: #include sidio h main() char s=“012xy 08s34f4w2“; int i, n=0; for(i=0; si!=0; i+) if(si =0& si =9)n+; printf(“ d n“, n); 程序运行后的输出结果是 ( )。 ( A) 0 ( B) 3 ( C) 7 ( D) 8 33 有以下程序:

17、#include stdio h fun(int x, int y) static int m=0, i=2; i+=m+1; m=i+x+y; return m; main() int j=1, m=1, k; k=fun(j, m); printf(“ d, “, k); k=fun(j, m); printf(“ d n“, k); 程序执行后的输出结果是 ( )。 ( A) 5, 11 ( B) 5, 5 ( C) 11, 11 ( D) 11, 5 34 在 C语言中,只有在使用时才占用内存单元的变量,其存储类型是 ( )。 ( A) auto和 static ( B) extern

18、和 register ( C) auto和 register ( D) static和 register 35 下面结构体的定义语句中,错误的是 ( )。 ( A) struct ordintx; int y; int z; struct ord a; ( B) struct ordintx; int y; int z; ; struct ord a; ( C) struct ordintx; int y; int z; a; ( D) struct int x; int y; int z; a; 36 有以下程序: #include stdio h typedef structint b,

19、p; A; void f(A c) *注意: c是结构变量名 * int j; c b+=1; c p+=2; main() int i: A a=1, 2: f(a); printf(“ d, d n“, a b, a p); 程序运行后的输出结果是 ( )。 ( A) 2, 4 ( B) 1, 2 ( C) 1, 4 ( D) 2, 3 37 以下叙述中正确的是 ( )。 ( A)在 C语言中,预处理命令行都以 “#”开头 ( B)预处理命令行必须位于 C源程序的起始位置 ( C) #include stdio h必须 放在 C程序的开头 ( D) C语言的预处理不能实现宏定义和条件编译的

20、功能 38 有以下程序: #include stdio h #include stdlib h int fun(int n) int*p; p=(int*)malloc(sizeof(int); *p=n; return*p; main() int a; a=fun(10); printf(“ d n“, a+fun(10); 程序运行后的输出结果是 ( )。 ( A) 0 ( B) 10 ( C) 20 ( D)出错 39 有以下程序: #include stdio h main() unsigned char a=8, c; e=a 3: printf(“ d n“, c); 程序运行后的

21、输出结果是 ( )。 ( A) 16 ( B) 1 ( C) 32 ( D) 0 40 读取二进制文件的函数调用形式为: fread(buffer, size, count, fp);,其中buffer代表的是 ( )。 ( A)一个内存块的字节数 ( B)一个整型变量,代表待读取的数据的字节数 ( C)一个文件指针,指向待渎取的文件 ( D)一 个内存块的首地址,代表读人数据存放的地址 二、程序填空题 41 下列给定程序中,函数 fun的功能是:从形参 ss所指字符串数组中,删除所有串长超过 k的字符串,函数返回剩余字符串的个数。 ss所指字符串数组中共有 N个字符串,且串长小于 M。 请在

22、程序的下划线处填入正确的内容并将下划线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK1 C中。 不得增行或删行,也不得更改程序的结构 ! #include stdio h #include string h #define N5 #define M10 int fun(char(*ss)M, int k) int i, j=0, len; *found* for(i=0; i 11; i+) len=strlen(ssi); *found* if(len =2) *found* strcpy(ssj+, 3); return j; main() char xNM=“Beiji

23、ng“, “Shanghai“, “Tianjin“, “Nanjing“, “Wuhan“; int i, f; printf(“ nThe original string n n“); for(i=0; i N; i+) puts(xi); printf(“ n“); f=fun(x, 7); printf(“The string witch length is less than or equal to7: n“); for(i=0; i f; i+)puts(xi); printf(“ n“); 三、程序修改题 42 下列给定 程序中函数 fun的功能是:用递归算法计算斐波拉契数列中第

24、 n项的值。从第 1项起,斐波拉契数列为: 1、 1、 2、 3、 5、 8、 13、 21、 例如,若给 n输入 7,则该项的斐波拉契数值为 13。 请改正程序中的错误,使它能得出正确的结果。 注意:部分源程序在文件 MODI1 C中,不得增行或删行,也不得更改程序的结构。 #include stdio h long fun(int g) *found* switch(g); case0: return0; *found* ease1; ease2: retum1; return(fun(g-1)+fun(g-2); main() long fib; int n; printf(“Input

25、 n: “); scaRf(“ d“, &n); printf(“n= d n“, n); fib=fun(n); printf(“fib= d n n“, fib); 四、程序设计题 43 编写函数 fun,其功能是:将所有大于 1小于整数 m的非素数存入 xx所指数组中,非素数的个数通 过 k返回。 例如,若输入 17,则应输出: 46891012141516。 注意:部分源程序在文件 PROG1 C中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 #include stdio h void fun(int m, int*k, int

26、xx) main() int m, n, zz100; void NONO(); printf(“ nPlease enter an integer number between10and100: “); scanf(“ d“, &n); fun(n, &m, zz); printf(“ n nThere are d non-prime numbers less than d: “, m, n); for(n=0; n m; n+) printf(“ n 4d“, zzn); NONO(); void NONO() *请在此函数内打开文件,输入测试数据,调用 fun函数, 输出数据,关闭文件。

27、 * int m, n, zz100; FILE*rf, *wf; rf=fopen(“in dat“, “r“); wf=fopen(“out dat“, “w“); fscanf(rf, “ d“, &n); fun(n, &m, zz); fprinff(wf, “ d、 n d n“, m, n); for(n=0; n m; n+) fprintf(wf, “ d n“, zzn); fclose(rf); fclose(wf); 国家二级( C语言)机试模拟试卷 96答案与解析 一、选择题 1 【正确答案】 C 【试题解析】 在数据流图中,用标有名字的箭头表示数据流。在程序流程图中

28、,用标有名字的箭头表示控制流。所以选择 C。 2 【正确答案】 A 【试题解析】 结构化程序设计的思想包括:自顶向下、逐步求精、模块化、限制使川 goto语句,所以选择 A。 3 【正确答案】 B 【试题解析】 软件设计中模块划分应遵循的准则是高内聚低偶合、模块大小规模适当、模块的依赖关系适当等。模块的划分应遵循一定的要求,以保证模块划分合理,并进一步保证以此为依据开发出的软件系统可靠性强,易于理解和维护。模块之间的耦合应尽可能的低,模块的内聚度应尽可能的高。 4 【正确答案】 B 【试题解析】 A错误,可行性分析阶段产生可 行性分析报告。 C错误,概要设计说明书是总体设计阶段产生的文档。 D

29、错误,集成测试计划是在概要设计阶段编写的文档。 B正确,需求规格说明书是后续工作如设计、编码等需要的重要参考文档。 5 【正确答案】 A 【试题解析】 算法原则上能够精确地运行,而且人们用笔和纸做有限次运算后即可完成。有穷性是指算法程序的运行时间是有限的。 6 【正确答案】 D 【试题解析】 除了堆排序算法的比较次数是 O(nlog2, n),其他的都是, n(n-1)2。 7 【正确答案】 B 【试题解析】 栈是按 “先进后 出 ”的原则组织数据的,数据的插入和删除都在栈顶进行操作。 8 【正确答案】 C 【试题解析】 ER图转换成关系模型数据则是把图形分析出来的联系反映到数据库中,即设计出

30、表,所以属于逻辑设计阶段。 9 【正确答案】 D 【试题解析】 自然连接是一种特殊的等值连接,它要求两个关系中进行比较的分量必须是相同的属性组,并且在结果中把重复的属性列去掉,所以 B错误。笛卡尔积是用 R集合中元素为第一元素, S集合中元素为第二元素构成的有序对,所以 C错误。根据关系 T可以很明显地看出是从关系 R与关系 S中取得相 同的关系组所以取得是交运算,选择 D。 10 【正确答案】 C 【试题解析】 学号是学生表 S的主键,课号是课程表 C的主键,所以选课表 SC的关键字就应陔是与前两个表能够直接联系且能唯一定义的学号和课号,所以选择 C。 11 【正确答案】 A 【试题解析】

31、C语言中的非执行语句不会被编译,不会生成二进制的机器指令,所以 A错误。由 C语言构成的指令序列称 C源程序, C源程序经过 C语言编泽程序编译之后生成一个后缀为 OBJ的二进制义件 (称为目标文件 );最后要由 “连接程序 ”把此 OBJ文件与 C语言提供的各 种库函数连接起来生成一个后缀为 EXE的可执行文件。 12 【正确答案】 A 【试题解析】 C语言中八进制整型常量的开头是数字 0,十六进制整型常量的数字开头是 0x。 C语言中的实型常量有两种表示形式:小数形式,小数形式表示的实型常量必须要有小数点;指数形式,以 “e”或 “E”后跟一个整数来表示以 10为底数的幂数,且规定字母 e

32、或 E之前必须要有数字,且 e或 E后面的指数必须为整数。 B选项中 028错误,八进制中没有数字 8。 C选项中 4e1 5中 e后面的指数不是整数。 D选项中 3 e5小数点后面缺少数字。 13 【正确答案】 A 【试题解析】 C语占中标识符由字母、下划线、数字组成,且开头必须是字母或下划线。另外,关键字不能作为标识符。因为 C语言中区分大小写,所以 B选项中的 “FOR”可以作为标识符来用。 A选项中含有非法字符 &,所以选择 A。 14 【正确答案】 A 【试题解析】 B选项中函数 pow(x, e)错误应该直接使用 exp(x)函数。 C选项中函数 abs(n x+e x)错误,应该

33、使用 fahs()返回浮点数的绝对值。 D选项中pow(x, n)参数顺序错误。 15 【正确答案】 B 【试题 解析】 取模运算符 “ ”,二元运算符,具有左结合性,参与运算的量均为整型。选项 B中的 a变量是 double实型,所以 B不符合规定。 16 【正确答案】 D 【试题解析】 C语言中利用 sizeof()函数判断数据类型长度,在 VC6 0平台中,整型 int占有 4个字节, double型数据占有 8个字节。 17 【正确答案】 D 【试题解析】 按照从键盘输入的数据可以判断字符 1给了变量 a,字符 2给了变量 b,字符 CR即回车给了变量 c,字符 3给了变量 d。所以打

34、印输出的结果为D选项。 18 【正确 答案】 A 【试题解析】 C语言的逻辑运算符比较特别,它的操作数没有明确的数据类型,可以是任意合法的表达式,所以选择 A。 19 【正确答案】 C 【试题解析】 本题中 if(a=1)b=1;与 else d=3;之间多了语句 c=2;所以会出现else语句的位置错误的编译失败提示。 20 【正确答案】 B 【试题解析】 tase常量表达式只是起语句标号作用,并不是陔处进行条件判断。在执行 switch语句时,根据 switch的表达式,找剑与之匹配的 case语句,就从此case子句执行下去, 不在进行判断,直到碰到 break或函数结束为止。所以执行内

35、层 switch(y)时只执行了 a+,此时 a的值为 1。然后执行外层 case2讲句的a+; b+; a为 2, b为 1。所以结果为 B。 21 【正确答案】 C 【试题解析】 由于内层循环 for(k=1; k 3; k+)后面直接跟了空语句 “; ”所以在循环内部什么操作也不做,跳 “出外层循环后执行打印语句,所以打印了一个“*”,选择 C。 22 【正确答案】 D 【试题解析】 case常量表达式只是起语句标号作用,并不是该处进行条件判断。在执行 switch讲句时,根据 switch的表达式,找到与之匹配的 case讲句,就从此case子句执行下去,不再进行判断,直到碰到 hre

36、ak或函数结束为止。简单的说break是结束整个循环体,而 continue是结束单次循环。 B选项中当产生的随机数n为 4时要执行打印操作。 C选项中当产生的随机数为 1和 2时分别执行 case3与case4后面语句的内容。由于存在 break语句所以 for循环不是同定执行 8次,执行次数与产生的随机数 n有关系。 23 【正确答案】 A 【试题解析】 第一次调用 m=f(f(f(1),第二次为 m=f(f(2),第三次为 m=f(4),即返回值为 8。 24 【正确答案】 A 【试题解析】 不能将一个整数直接赋给指针变量作为地址,昕以 A是错误的。函数的返回值可以是地址,即指针。函数调

37、用中形参值的变化不会传递给实参。 25 【正确答案】 B 【试题解析】 指针是用来存放地址的变量,用 (类型名 *指针变量名 )的形式定义。赋值时应将某个变量地址即 &x赋给指针变量,所以选择 B。 26 【正确答案】 D 【试题解析】 1)选项中 x23定义的是一个两行三列的二维数 组,而在给数组元素赋值时却赋成了三行,所以错误。 27 【正确答案】 A 【试题解析】 本题中的函数 fun()的功能是将数组 k中前 5个元素倒序,所以返回后数组 k中的元素排列是 5, 4, 3, 2, 1, 6, 7, 8, 9, 10。所以打印输出 k2到 k7元素的值,即 321678,所以选择 A。

38、28 【正确答案】 A 【试题解析】 本题中由 fun函数可知, b0=a00-a03=1-4=-3, b1=a11-12=6-7=-1, b2=a22-21=11-10=1, b3=a33-31=16-13=3。所以主函数中打印 y数组元素的值为 A选项。 29 【正确答案】 C 【试题解析】 字符串的输入不能使用 scanf(“ s“, s);而应该使用 gets(s)。 30 【正确答案】 A 【试题解析】 根据题目中的定义可以知道 sizeof(p),计算的是数组 p中所有元素所占州的字节数,而不是 char型数据所占字节数。 31 【正确答案】 A 【试题解析】 p是指向二维字符数组

39、第二行 One*Dream!的数组指 针,所以长度是 10,打印输出的也是该字符串。 32 【正确答案】 B 【试题解析】 本题中遇到 “ ”字符循环结束,所以只统计 “ ”之前的数字字符,所以为 3。 33 【正确答案】 A 【试题解析】 声明静态局部变量:函数调用结束后,其占用的存储单元不释放,在下次该函数调用时,该变量保留上一次函数调用结束时的值。本题子函数 fun中的变量 i和 m均为静态局部变量。所以第一次调用 fun函数,返回 m的值为5,第二次再调用 fun函数时, i的值为 3, m的值已经是 5了,所以执行i+=m+1, j的值变为 9, m=i+x+y=9+1+1=11。

40、34 【正确答案】 C 【试题解析】 auto:函数中的局部变量,动态地分配存储空间,数据存储在动态存储去中,在调用该函数时系统会给它们分配存储空间,在函数渊用结束时就自动释放这些存储空间。 register:为了提高效率, C语言允许将局部变量的值放在CPU中的寄存器中,这种变量叫 “寄存器变量 ”,只有局部自动变量和形式参数可以作为寄存器变量。 extern:外部变量 (即全局变量 )是在函数的外部定义的,它的作用域为从变量定义处开始,到本程序文件的未尾。如果外部变量不在 文件的开头定义,其有效的作用范围只限于定义处到文件终了。 static:静态局部变量属于静态存储类别,在静态存储区内分

41、配存储单元。在程序整个运行期间都不释放。 35 【正确答案】 A 【试题解析】 A选项 struct ordint x; int y; int z; struct ord a;错误,不能在定义结构体的同时,又用结构体类型名定义变量。应该写成 B选项或者 D选项的格式。 36 【正确答案】 B 【试题解析】 结构体变量可以作为函数的参数和返回值。作为函数的实参时,可以实现函数的传值调 用。当使用结构体变量作为函数的形参时,实参也应该是结构体变量名以实现传值调用,实参将拷贝副本给形参,在被渊用函数中改变形参值对于调用函数中的实参没有影响。所以选择 B。 37 【正确答案】 A 【试题解析】 预处理

42、命令是以 “#”号开头的命令,它们不是 C语言的可执行命令,这些命令应该存函数之外书写,一般在源文件的最前面书写,但不是必须在起始位置书写,所以 B、 C错误。 C语言的预处理能够实现宏定义和条件编译等功能,所以 D错误。 38 【正确答案】 C 【试题解析】 malloc-(sizeof(int)的作用是开辟一个长度为 sizeof(int)存储空间,并通过强制类型转换 (int*)将此存储空间的地址赋给了一个整型的指针变量 p。然后执行语句 *p=n,使得 *p的值为 10,并通过 return返回此值,即 a的值为 10。然后在主函数中输出 a+fun(10)=10+10=20。 39

43、【正确答案】 B 【试题解析】 无符号整型变量 a的值为 8,二进制表示为 00001000,右移 3位后为 00000001,即十进制的 1,所以输出 1。 40 【正确答案】 D 【试题解析】 fread(void*buffer, size_t size, siZe_t count, FILE*stream);功能是从一个义文件流中读数据,读取 count个元素,每个元素 size字节,如果调用成功返回 count。 buffer:用于接收数据的内存地址,大小至少是 size*count字节;size:单个元素的大小,单位是字节; count:元素的个数,每个元素是 size字节; str

44、eam:输入流。 二、程序填空题 41 【正确答案】 (1)N (2)k (3)ssi。 【试题解析】 本题考查: for循环语句, if;语句条件表达式;字符串拷贝函数strcpy的使用。 字符串拷贝函数 strcpy,其格式为: strcpy(字符数组名 1,字符数组名 2) 功能:把字符数组 2中的字符串拷贝到字符数组 1中。字符串结束标识 0也一同拷贝。字符数名 2,也可以是一个字符串常量。这时相当于把一个宇符串赋予一个字符数组。 三、程序修改题 42 【正确答案】 (1)去掉分号 (2)case1: case2: return1;。 【试题解析】 本题考查: switch语句,其一般

45、形式为: switch(表达式 ) case常量表 达式 1:语句 1; case常量表达式 2:语句 2; case常量表达式 n:语句 n; defaull:语句 n+1; 其中 swilch(表达式 )后不应该带有 “; ”,同时 case语句常量后应陔是 “: ”。 C语言中, switch语句之后小能有分号,并且 case语句常量后应用的是冒号。 四、程序设计题 43 【正确答案】 void fun(int m, int*k, int xx) int i, j, n=0; for(i=4; i m; 1; i+) *找出大于 1小于整数 m的 非素数 * for(j=2; j i;

46、j+) if(i j=0)break; if(j i)xxn+=i; *k=n; *返回非素数的个数 *。 【试题解析】 本题考查:如何判断非素数;循环判断结构;数组的引用。 题目要求将 1 m之间的非素数存入数组中,应使用循环判断结构。询环讲句用来遍历 1 m之间的每个数,判断语句用来判断该数是否为素数,若不是素数,则将其存入数组中。这道题目是考查一个数是否为素数的简单延伸,只要掌握了判断素数的方法,问题便能顺利解决,判定一个数是否为素数,即该数除了能被 1和它本身外,不能被任何数整除 代 码实现为: for(j=2; j i; j+) if(i j=0) *如余数为 0,证明 i不是是素数 * 此语句需要熟记,很多判断素数的题目也可通过此法解决。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1