1、国家二级 C语言机试(操作题)模拟试卷 578及答案与解析 一、程序填空题 1 下列给定程序中,函数 fun的功能是:把形参 a所指数组中的偶数按原顺序依次存放到 a0、 a1、 a2 中,把奇数从数组中删除,偶数的个数通过函数值返回。 例如,若 a所指数组中的数据最初排列为: 9、 1、 4、 2、 3、 6, 5、 8、 7,删除奇数后, a所指数组中的数据为: 4、 2、 6、 8,返回值为 4。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构 ! 试题程序: #include stdio h #d
2、efine N 9 int fun(int a, int n) int i, j; j=0; for (i=0; i n; i+) *found* if(【 1】 =0) *found* 【 2】 =ai; j+; *found* return【 3】 ; main() int bN=9, 1, 4, 2, 3, 6, 5, 8, 7, i, n; printf(“ nThe original data: n“); for(i=0; i N; i+) printf(“ 4 d“, bi); printf(“ n“); n=fun(b, N); printf(“ nThe number of e
3、verl : d n“, n); printf(“ nThe even: n“); for(i=0 ; i n; i+) printi(“ 4 d“, bi); printf(“ n“); 二、程序修改题 2 下列给定程序中,函数 fun的功能 是:按以下递归公式求函数的值。例如,当给 n输入 5时,函数值为 18;当给n输入 3时,函数值为 14。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构 ! 试题程序:#include stdio h *found* fun(n) int c;*found* if(n=1) c=10;
4、else c=fun(n1)+2; return(c); main() int n; printf(“Enter n: “); scanf(“ d“, n); printf(“The result: d n n“, fun(n); 三、程序设计题 3 规定输入的字符串中只包含字母和 *号。请编写函数 fun,其功能是:使字符串中尾部的 *号不多于 n个,若多于 n个,则删除多余的 *号;若少于或等于 n个,则不做任 何操作,字符串中间和前面的 *号不删除。 例如,字符串中的内容为 “*A*BC*DEF*G*”,若 n的值为 4,删除后,字符串中的内容应为 “*A*BC*DEF*G*”;若 n的
5、值为 7,则字符串中的内容仍为 “*A*BC*DEF*G*”。 n的值在主函数中输入。编写函数时,不得使用 C语言提供的字符串函数。 注意:部分源程序给出如下。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 试题程序: #include stdio h void fun(char*a, int n) main() char s81; int n; printf(“Enter a string: n“); gets(s); printf(“Enter n: “); scanf(“ d“, &n); fun(s, n); printf(“The
6、string after deleted: n“); puts(s); 国家二级 C语言机试(操作题)模拟试卷 578答案与解析 一、程序填空题 1 【正确答案】 (1)ai 2 (2)aj (3)j 【试题解析】 本题考查: if语句条件表达式;数组变量赋值;函数返回值。 填空 1: if语句条件表达式,判断数组元素是否为偶数,对 2求余,结果为 0,则为偶数;结果为 1则为奇数。 填空 2:如果该数组元素是偶数,则将其值保存。 填空 3:最后按要求将偶数个数通过 return语句返回给 main函数。 二、程序修改题 2 【正确答案】 (1)int fun(int n) (2)if(n=1
7、) 【试题解析】 本题考查:有参函数定义; if语句条件表达式中 =与 =的区别。 (1)定义有参函数时,形参变量要分别定义其类型,根据主函数中的调用函数可知,此处形参变量应定义为 int型。 (2)if条件判断表达式中, n=1是赋值表达式,表达式的值永远为真,不能形成判断条件,应将 n=l改为 n=1。 三、程序设计题 3 【正确答案】 void fun(char, *a, int n) int i=0, k=0; char*p, *t; p=t=a; *将指针移动到字符串末尾 * while(*t) t+; t一一; *从后往前如果是 *则使 k+,找到最后一个术所在的位置,并记录 *的个数 * while(*t=*) *指针 t指向前一个,同时标量 k增加 * k+; t一一; ) *如果最后 *的个数大于允许的个数 */ if(k n) *循环次数不大于前面的字符与最大允许 *的个数之和 * while(*p p t+n+1) *把字符保存到数组 a中 * ai=*p; i+; p+; ai= 0; 【试题解析】 本题考查:循环判断语句;字符串的操作。 字符串中尾部 *号不能多于 n个,多余的要删除。首先需要通过 while循环统计字符串尾部 *号,然后通过 if条件语句完成尾部 *号数和 n的比较,若尾部 *号数多于n个,则需要把 n个 *号和其余字符重新保留。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1