1、国家二级 C语言机试(操作题)模拟试卷 261及答案与解析 一、程序填空题 1 给定程序中,函数 fun的功能是:计算出形参 s所指字符串中包含的单词个数,作为函数值返回。为便于统计,规定各单词之间用空格隔开。 例如,形参 s所指的字符串为: This is a C language program,函数的返回值为6。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK1 C中。 不得增行或删行,也不得更改程序的结构 ! 试题程序: #include stdio h int fun(char*S) int n=0, flag=0; whi
2、le(*S!= 0) if(*S!= flag=0) *found* 【 1】 ; flag=1; ) *found* if(*S=)flag=【 2】 ; *found* 【 3】 ; return n; main() char str81; int n; printf(“ nEnter a line text: n“); gets(str); n=fun(str); printf(“ nThere are d words in this text n n“, n); 二、程序修改题 2 给定程序 MODI1 C中, fun函数的功能是:在任意给定的 N个正整数中,从左到右依次逐个取三个数作
3、为一组,按值大小找出该组数的中值,用该中值替换与该组数对应的原三个数中的中间位置的数。处理后原数列中首尾 2个数不变。处理后数列在主函 数中输出。例如,有 10个正整数如下: 初始数列为: 6 5 7 23 18 5 8 21 45 38 第 1组数为: 6 5 7中值为: 6替换后的数列为: 6 6 7 23 18 5 8 21 45 38 第 2组数为: 5 7 23 中值为: 7替换后的数列为: 6 6 7 23 18 5 8 21 45 38 第 3组数为: 7 23 18中值为: 18替换后 的数列为: 6 6 7 18 18 5 8 21 45 38 第 4组数为: 23 18 5
4、 中值为: 18替换后的数列为: 6 6 7 18 18 5 8 21 45 38 第 5组数为: 18 5 8 中值为: 8替换后的数列为: 6 6 7 18 18 8 8 21 45 38 第 6组数为: 5 8 21 中值为: 8替换后的数列为: 6 6 7 18 18 8 8 21 45 38 第 7组数为: 8 21 45中值为: 21替换后的数列为: 6 6 7 18 18 8 21 45 38 第 8组数为: 21 45 38 中值为: 38替换后的数列为: 6 6 7 18 18 8 8 21 38 38 最终结果为: 6 6 7 18 18 8 8 21 38 38 请 改正
5、程序中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构 ! 试题程序: #include stdio h #define N 10 int findmid(int a, int b, int c) int t; t=(a b)? (b c?b: (a c?c: a): (a c)?a: (b c)?c: b); *found* return b; void fun(int x) int i, a, b, c, tN; *found* for(i=0; i N; i+)ti=xi for(i=0; i N 2; i+) a=ti; b=t
6、i+1; c=ti+2; *found* ti+1=findmid(a, b, c); main() int i, xN=6, 5, 7, 2 3, 18, 5, 8, 21, 45, 38); for(i=0; i N; i+) printf(“ d“, xi); printf(“ n“); fun(x); for(i=0; i N; i+) printf(“ d“, xi); printf(“ n“); 三、程序设计题 3 规定输入的字符串中只包含字母和 *号。请编写函数 fun,其功能是:使字符串中尾部的 *号不多于 F1个,若多于 n个,则删除多余的 *号;若少 于或等于 11个,则不
7、做任何操作,字符串中间和前面的木号不删除。 例如,字符串中的内容为 “*A*BC*DEF*G*”,若 n的值为 4,删除后,字符串中的内容应为 “*A*BC*DEF*G*”;若 n的值为 7,则字符串中的内容仍为 “*A*BC*DEF*G*”。 n的值在主函数中输入。编写函数时,不得使用 C语言提供的字符串函数。 注意:部分源程序给出如下。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 试题程序: #include stdio h void fun(char*a, int n) rnain() char s81; int n; printf(
8、“Enter a string: lq“); gets(s); printf(“Enter n: “); scanf(“ d“, n); fun(s, n); printf(“The string after deleted: n“); puts(s); 国家二级 C语言机试(操作题)模拟试卷 261答 案与解析 一、程序填空题 1 【正确答案】 (1)n+ (2)0 (3)s+ 【试题解析】 填空 1:单词个数用变量 n来统计,当前字母不是空格且 flag状态标志为 0时,可以判断出现一个新的单词,则单词数就加 1,将状态标志 flag置为1,所以应填 n+。 填空 2:当前字符是空格时,
9、flag状态标志置 0,所以应填 0。 填空 3:判断完一个字符之后,要继续判断字符串的下一个位置,所以应填 s+。 二、程序修改题 2 【正确答案】 (1)rettim t; (2)for(i=0; i N; i+)ti=xi; (3)xi+1=findmid(a, b, c); 【试题解析】 (1)函数 findmid的功能是找到 a、 b、 c三个数中的中间数,并存放在变量 t中,因此应返回 t。 (2)语法错误,句末缺少分号。 (3)本程序是对数组 x进行操作,数组 t只是用来暂时存放数组 x中的元素,因此此处应为 xi+1=findmid(a, b, c)。 三、程序设计题 3 【正
10、确答案】 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个 *号和其余字符重新保留。