[计算机类试卷]2013年3月国家二级(C语言)机试真题试卷及答案与解析.doc

上传人:周芸 文档编号:493074 上传时间:2018-11-30 格式:DOC 页数:26 大小:72KB
下载 相关 举报
[计算机类试卷]2013年3月国家二级(C语言)机试真题试卷及答案与解析.doc_第1页
第1页 / 共26页
[计算机类试卷]2013年3月国家二级(C语言)机试真题试卷及答案与解析.doc_第2页
第2页 / 共26页
[计算机类试卷]2013年3月国家二级(C语言)机试真题试卷及答案与解析.doc_第3页
第3页 / 共26页
[计算机类试卷]2013年3月国家二级(C语言)机试真题试卷及答案与解析.doc_第4页
第4页 / 共26页
[计算机类试卷]2013年3月国家二级(C语言)机试真题试卷及答案与解析.doc_第5页
第5页 / 共26页
点击查看更多>>
资源描述

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

2、5 算法的有穷性是指 ( )。 ( 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 0Xa23 4 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) sqrt(fabs(tow(n, x)+exp(x) ( B) sqrt(fabs(tow(n, X)+pow(x, e) ( C) sqrt(abs(nx+ex) ( 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 有以下程

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

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

8、, a, b, c, d); 程序输出 ( )。 ( A) 1, 1, 2, 0 ( B) 0, 0, 0, 3 ( C)编译有错 ( D) 0, 1, 2, 0 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= d n“, a, b); 程序的运行结果是 ( )。 ( A) a=2, b=2 ( B)

9、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 int i, n; for(i=0; i 8; i+) n=rand() 5; switch(n) case 1: case 3: printf(“ d、 n“, n); break; case 2: case 4: printf(“ d n“, n);

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

11、 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) float*P=1024; 26 以下数组定义中 错误的是 ( )。 ( A) int x23=1,

12、2, 3, 4, 5, 6; ( B) int x3=0; ( C) int x儿 3=l, 2, 3, 4, 5, 6; ( D) int x23=1, 2, 3, 4, 5, 6; 27 有以下程序: include 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); for(i: 2; i 8; i+)printf(“ d“, ki); printf(“ n“);

13、程序的运行结果是 ( )。 ( A) 321678 ( B) 876543 ( C) 1098765 ( D) 345678 28 有以下程序: #inelude #define N 4 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(x, y); for(i=0; i N; i+)printf(“ d, “, yi); printf(“ n“); 程序运行

14、后的输出结果是 ( )。 ( 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+=getchar()!= n); si= 0; ( C) scanf(“ s“, s); ( D) doscanf(“ c“, &si); while(si+!= n); Si= 0; 30 设有定义: char P

15、=1, 2, 3, *q=p;,以下不能计算出一 个 char型数据所占字节数的表达式是 ( )。 ( A) sizeof(p) ( B) sizeof(char) ( C) sizeof(*q) ( D) sizeof(p0) 31 有以下程序: #include #include main() char str20=“One*World“, “One*Dream!“, *p=str1; pfinff(“ d, “, strlen(p); pfinff(“ s n“, p); 程序运行后的输出结果是 ( )。 ( A) 10, One*Dream! ( B) 9, One*Dream! (

16、C) 9, One* World ( D) 10, One* World 32 有以下程序: #include main() char s=“012xy 08s34f4w2“; int i, n=0; for(i=0; Si!=0; i+) if(Si=0&si =9)n+; pfinff(“ d n“, n); 程序运行后的输出结果是 ( )。 ( A) 0 ( B) 3 ( C) 7 ( D) 8 33 有以下程序: #include fun(int x, int y) static int m=0, i=2; i+=m+1; m=i+x+y; retum m; main() int j=

17、1, m=1, k; k=fun(j, m); pfinff(“ 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) extem和 register ( C) auto和 register ( D) static和 register 35 下面结构体的定义语句中,错误的是 ( )。 ( A) struct ordint x

18、; int y; int z; struct ord a; ( B) struct ordint x; int y; int Z; ; struct ord a; ( C) struct ordint x; int y; int z; a; ( D) structint x; int y; int z; a; 36 有以下程序: #include typedef structint b, p; A; void f(A C) *注意: c是结构变量名 * int j; (C)b+=1; (C)P+=2; main() int i; A a=1, 2; f (A); prinntf(“ d, d

19、n“, (ab, a)p); 程序运行后的输出结果是 ( )。 ( A) 2, 4 ( B) 1, 2 ( C) 1, 4 ( D) 2, 3 37 以下叙述中正确的是 ( )。 ( A)在 C语言中,预处理命令行都以 “#”开头 ( B)预处理命令行必须位于 C源程序的起始位置 ( C) #include必须放在 C程序的开头 ( D) C语言的预处理不能实现宏定义和条件编译的功能 38 有以下程序: #include #nclude int fun(int n) int*p; p=(int*)maUoc(sizeof(int); *p=n; return*p; main() int a;

20、a=fun(10); printf(“ d n“, a+fun(10); 程序的运行结果是 ( )。 ( A) 0 ( B) 10 ( C) 20 ( D)出错 39 有以下程序: #include main() unsigned char a=8, C; c=a 3; printf(“ d n“, C); 程序运行后的输出结果是 ( )。 ( A) 16 ( B) 1 ( C) 32 ( D) 0 40 读取二进制文件的函数调用形式为: fiead(buffer, size, count, fp);,其中buffer代表的是 ( )。 ( A)一个内存块的字节数 ( B)一个整型变量,代表待

21、读取的数据的字节数 ( C)一个文件指针,指向待读取的文件 ( D)一个内存块的首地址,代表读人数据存放的地址 二、程序填空题 41 下列给定程序中,函数 fun的功能是:计算如下公式 直到 ,并且把计算结果作为函数值返回。例如,若形参 e的值为 1e-3,则函数返回值为0 551690。请在下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。注意:部分源程序给出 如下。不得增行或删行。也不得更改程序的结构 !试题程序: #includedouble fun(double e) int i t k; double s , t, x; s=0; k=1; i=2;*found* x=【

22、1】 4 ; *found* while(x 【 2】 e) s=s+k*x; k=k*(-1); t=2*i; *found* x=【 3】 (t*t), i+; return S; main()double e=1e-3; printf(“ nThe result is: f n“, fun(e); 三、程序修改题 42 下列给定程序中函数 fun的功能是:求出如下分数序列的前 n项之和,和值通过函数值返回。 例如,若 n=5,则应输出 8 391667。请改正程序中的错误,使其得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构 !试题程序: #includ

23、e#include#include *found* void fun(int n)int a=2 , b=1 , c, k; double s=0 0; for(k=1; k =n ; k+)*found* s=s+(Double)a b; c=a; a=a+b;b=C; return(s); void main()int n=5; system(“CLS“); printf(“ nThe value of function is: 1 f n“, fun(n); 四、程序设计题 43 请编写函数 fun,其功能是:找出 2M整型二维数组中最大元素的值,并将此值返回调用函数。 注意:部分源程序

24、给出如下。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 试题程序: #define M 4 #include int fun(int aM) void main() int arr2M=5, 8, 3, 45, 76, -4, 12, 82; printf(“max= d n“, fun(arr); 2013年 3月国家二级( C语言)机试真题试卷答案与解析 一、选择题 1 【正确答案】 C 【试题解析】 在数据流图中,用标有名字的箭头表示数据流。在程序流程图中,用标有名字的箭头表示控制流。所以选择 C)。 2 【正确答案】 A 【试题解析

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

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

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

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

29、必须为整数。 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(nx+ex)错误,应该使用 fabs()返回浮点数的绝对

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

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

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

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

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

35、21678,所以选择 A)。 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

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

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

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

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

40、 a+fun(10)=10+10=20。 39 【正确答案】 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:单个元素的大小,单位是字节; coun

41、t:元素的个数,每个元素是 size字节; stream:输入流。 二、程序填空题 41 【正确答案】 【 1】 3 0或 (double)3 【 2】 【 3】 (t+1) 【试题解析】 本题考查:基本算术运算的类型转换。其转换规则如下: 如果双目运算符两边运算数的类型一致,则所得结果的类型与运算数的类型一致。 如果双目运算符两边运算数的类型不一致,系统将 自动进行类型转换,使运算符两边运算数的类型达到一致后再进行运算。其类型转换规律见下表。 while循环语句,一般考查如何根据题意确定循环条件,以及如何通过循环变量的变化实现循环操作。 填空 1:变量 x定义为 double类型,而运算符

42、“ ”后面是整型数,因此给 x赋值时,需要注意数据类型,此处不能将 3 0写成 3。 填空 2: while循环语句的循环条件。根据题意确定循环变量应大于 1e-3,因此此处应填 “ ”。 填空3:表达式的通项是 (2*i+1) (2*i)2,由于程序中已定义 t=2*i,所以此处应该填写(t+1)。 本题填空 1还可以运用强制类型转换来实现。强制类型转换是通过类型转换运算来实现的,其一般形式为 “(类型说明符 )(表达式 )”。 其功能是:把表达式的运算结果强制转换成类型说明符所表示的类型。 例如: (float)a 把 a转换为实型 (int)(x+y) 把 x+y的结果转换为整型 三、程

43、序修改题 42 【正确答案】 (1)double fun(int n) (2)s=s+(double)a b; 【试题解析】 本题考查:函数定义,函数定义的一般形式为 “类型标识符函数名(形式参数表列 )”,其中类型标识符用来说明函数值的类型,函数的类型实际上是函数返回值的类型。 (1)由语句 “return(s); ”和变量 s定义为 double型可知,该函数定义时其类型标识符为 double类型。 (2)注意数据类型 double的书写格式。 确定函数类型标识符在填空和改错题中经常考到,如果函数没有返回值,则函数定义为 void型;如果函数有返回值,则函数类型应与返回值类型一致;如果不定

44、义函数类型标识符,则系统默认为 int型。 四、程序设计题 43 【正确答案】 int fun(int aM) int i, j, max=a00; *对二维数组进行遍历 * for(i=0 ; i 2; i+) for(j=0; j M; j+) if(maxaij) *将最大值保存在 max中 * max=aij; return max; 【试题解析】 本题考查:求数组的最大值,需运用循环语句。因为数组是二维数值,所以应使用二层加 for循环嵌套。使用 for循环语句时需注意循环变量的取值范 围。 此类求最大值或最小值的问题,可以采用逐个比较的方式,对数组中所有元素遍历一遍,从中找出数组最大值或最小值。首先定义变量 max用来存放数组的第一个元素的值,然后利用 for循环逐个找出数组中的元素,并与 max比较,如果元素值大于 max,则将该值赋予 max,循环结束后 max的值即为数组最大值,最后将该值返回。 该类题目考查较多,需要掌握逐个比较的方法。对于 m*n二维数组,如果采用逐个查找方法,代码实现如下: for(i=0; i m, i+) for(j=0; j n; j+) if(ai, j max) max=ai, j

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

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

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