1、二级 C 语言机试 85 及答案解析(总分:100.00,做题时间:90 分钟)一、B填空题/B(总题数:1,分数:30.00)1.请补充函数 fun(),该函数的功能是:求 100(不包括 100)以内能被 2 或 5 整除,但不能同时被 2 和 5整除的自然数。结果保存在数组 bb 中,函数 fun()返回数组比元素的个数。 注意:部分源程序给出如下。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun()的横线上填入所编写的若干表达式或语句。 试题程序: #include stdio.h #define N 100 int fun (int bb ) int i, j; f
2、or(U 【1】 /U;i100; i+) if (i%1!=0 U 【3】 /U; main() int i, n; int bb N; clrscr (); n=fun (bb); for(i=0; in; i+) if (i%10=0) printf (“/n“); printf (“% 4d“, bb i); (分数:30.00)填空项 1:_二、B改错题/B(总题数:1,分数:30.00)2.已知一个数列从 0 项开始的前 3 项:0,0,1,以后的各项都是其相邻的前 3 项之和。下列给定的程序中,函数 fun()的功能是:计算并输出该数列前。项的平方根之和 sum。n 的值通过形参
3、传入。例如,当n=10 时,程序的输出结果应为 23.197745。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构 试题程序: #include conio.h #include stdio.h #include math.h /*found*/ fun (int n) double sum, s0, s1, s2, s; int k; sum=1.0; if (n=2) sum=0.0; s0=0.0; sl=0.0; s2=1.0; for (k=4; k=n; k+) s=s0+s1+s2; sum+=sqrt (s);
4、 s0=s1; s1=s2; s2=s; /*found*/ return sum main ( ) int n; clrscr (); printf(“Input N=“); scanf (“%d“, print f (“%f/n“, fun (n); (分数:30.00)填空项 1:_三、B编程题/B(总题数:1,分数:40.00)3.请编写函数 fun(),该函数的功能是:将 M 行 N 列的二维数组中的字符数据,按列的顺序依次放到一个字符串中。 例如,若二维数组中的数据为: W WWW S S S S H H H H 则字符串中的内容应是WSHWSHWSHWSH。 注意:部分源程序给出
5、如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。 试题程序: #includestdio.h #define M 3 #define N 4 void fun(char (*s)N,char *b) main() char a100,wMN= W, W, W, W, S, S, S, S,H, H, H, H; int i,j; printf(“The matrix:/n“); for(i=0;iM;i+) for(j=0;jN;j+) printf(“%3c“,wij); printf(“/n“); fun(w,a); printf
6、(“The A string:In“); puts(a); printf(“/n/n“); (分数:40.00)_二级 C 语言机试 85 答案解析(总分:100.00,做题时间:90 分钟)一、B填空题/B(总题数:1,分数:30.00)1.请补充函数 fun(),该函数的功能是:求 100(不包括 100)以内能被 2 或 5 整除,但不能同时被 2 和 5整除的自然数。结果保存在数组 bb 中,函数 fun()返回数组比元素的个数。 注意:部分源程序给出如下。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun()的横线上填入所编写的若干表达式或语句。 试题程序: #inc
7、lude stdio.h #define N 100 int fun (int bb ) int i, j; for(U 【1】 /U;i100; i+) if (i%1!=0 U 【3】 /U; main() int i, n; int bb N; clrscr (); n=fun (bb); for(i=0; in; i+) if (i%10=0) printf (“/n“); printf (“% 4d“, bb i); (分数:30.00)填空项 1:_ (正确答案:1 i=l, j=0 2 bbj+=i 3return j)解析:解析 填空 1:题目要求找 100 以内的自然数,而自
8、然数是从 1 开始的,所以 i 的初始值为 1。变量 j 声明时没有初始化,所以在这里初始化为 0,用来记录满足条件的自然数的个数。填空 2:将满足条件的白然数存于数组 bb 中,下标加 1 是为了下一次存储做准备。填空 3:题目要求 fun()函数返回数组bb 元素的个数,所以函数返回 j。二、B改错题/B(总题数:1,分数:30.00)2.已知一个数列从 0 项开始的前 3 项:0,0,1,以后的各项都是其相邻的前 3 项之和。下列给定的程序中,函数 fun()的功能是:计算并输出该数列前。项的平方根之和 sum。n 的值通过形参传入。例如,当n=10 时,程序的输出结果应为 23.197
9、745。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构 试题程序: #include conio.h #include stdio.h #include math.h /*found*/ fun (int n) double sum, s0, s1, s2, s; int k; sum=1.0; if (n=2) sum=0.0; s0=0.0; sl=0.0; s2=1.0; for (k=4; k=n; k+) s=s0+s1+s2; sum+=sqrt (s); s0=s1; s1=s2; s2=s; /*found*/
10、 return sum main ( ) int n; clrscr (); printf(“Input N=“); scanf (“%d“, print f (“%f/n“, fun (n); (分数:30.00)填空项 1:_ (正确答案:错误:fun(int n) 正确:double fun(int n))解析:(2)错误:return sum 正确:return sum; 解析 ANSI 新标准允许使用这样一种方法对形参类型做说明,即在列出“整型表列”时,同时说明参数类型。如: int max(int x,int y) . 相当于:int max(x,y) int x,y; . 又如:
11、 float fun(array, n) int array10,n; 可以写成 float fun(int array10,int n)三、B编程题/B(总题数:1,分数:40.00)3.请编写函数 fun(),该函数的功能是:将 M 行 N 列的二维数组中的字符数据,按列的顺序依次放到一个字符串中。 例如,若二维数组中的数据为: W WWW S S S S H H H H 则字符串中的内容应是WSHWSHWSHWSH。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。 试题程序: #includestdio.h
12、 #define M 3 #define N 4 void fun(char (*s)N,char *b) main() char a100,wMN= W, W, W, W, S, S, S, S,H, H, H, H; int i,j; printf(“The matrix:/n“); for(i=0;iM;i+) for(j=0;jN;j+) printf(“%3c“,wij); printf(“/n“); fun(w,a); printf(“The A string:In“); puts(a); printf(“/n/n“); (分数:40.00)_正确答案:()解析:void fun(char (*s) N,char *b) int i, j, k=0; for (i=0; iN; i+) /*按列的顺序依次放到一个字符串中*/ for (j=0; jM; j+) b k+ =s j i; bk=/0; 解析 看到程序后,我们很容易便能想到用循环嵌套的方法,本题中按列的顺序依次放到一个字符串中,所以列标变化慢,行标变化快。注意其中第 1 个循环条件为 iN(即列),第 2 个循环的条件为 JM(即行),这是因为在循环的嵌套中越在内层,循环变化就越快。另外,在编写程序中注意是 sji而非 sij。