1、国家二级 C语言机试(操作题)模拟试卷 571及答案与解析 一、程序填空题 1 下列给定程序中,函数 fun的功能是:在形参 ss所指字符串数组中,将所有串长超过 k的字符串中后面的字符删除,只保留前面的 k个字符。 ss所指字符串数组中共有 N个字符串,且串长小于 M。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构 ! 试题程序: #include stdio h #include string h #define N 5 #define M 10 *found* void fun(char(*ss)
2、【 1】 , int k) int i=0; *found* while(i 【 2】 ) *found* SSik=【 3】 ; i+; main() char xNM=“Create“, “Modi fy“, “Sort“, “skip“, “Delete“; int i; printf(“ nThe original string n n“); for(i=0; i N; i+)puts(xi); printf(“ n“); fun(x, 4); printf(“ nThe string after deleted: n n“); for(i=0; i N; i+) puts(xi);
3、printf(“ n“); 二、程序修改题 2 下列给定 程序中,函数 fun的功能是:根据以下公式求 值,并作为函数值返回。 例如,当给指定精度的变量 eps输入 0 0005时,应输出 Pi=3 140578。请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构 ! 试题程序: #include conio h #include stdio h #include math h double fun(double eps) double s, t; int n=1; s=0 0;*found* t=0; while(t eps) s+
4、=t; t=t*n (2*n+1); rl+; *found* return(s); void main() double x; printf(“ nPlease enter aprecision: “); scarlf(“ lf“, &x); printf(“ nPi= lf n“, fun(x); 三、程序设计题 3 规定输入的字符串中只包含字母和 *号。请编写函数 fun,其功能是:使字符串的前导 *号不得多于 n个,若多于 n个,则删除多余的 *号;若少于或等于 n个,则不做处理。字符串中间和尾部的 *号不删除。 例如,字符串中的内容为 “*A*BC*DEF*G*”,若 n的值为 4,
5、删除后,字符串中的内容应当是 “*A*BC*DEF*G*”;若 n的值为 8,则字符串中的内容仍为 “*A*BC*DEF*G*”。 n的值在主函数中输入。在编写函数时,不得使用 C语言提供的字符串函数。 注意:部分源程序给出如下。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 试题程序: #include stctio h #include conio h void fun(char*a, int n) void main() char s81; int n; printf(“Enter a string: n“); gets(s); pri
6、nt; f(“Enter n: “); Scanf(“ d“, &n); fun(s, n); printf(“The string after deleted: n“); puts(s); 国家二级 C语言机试(操作题)模拟试卷 571答案与解析 一、程序填空题 1 【正确答案】 (1)M (2)N (3) 0 【试题解析】 填空 1:根据 main函数中的函数调用语句,确定函数定义时的形式参数,所以填入 M。 填空 2: while循环语句需要对所有字符串进行操作,因此循环条件是 i N。 填空 3:字符串结尾加入字符串结束标识 0。 二、程序修改题 2 【正确答案】 (1)t=1 0;
7、(2)return(s*2); 【试题解析】 该题中,首先检查变量数据类型前后是否一致,因为变量 t定义为double型,所以赋值时要赋以实型数值。 return(s)是一个数学错误,应该返回return (s*2);。 三、程序设计题 3 【正确答案】 void fun(char*a, int n) int i=0, k=0; char*p, *t; p=t=a; *开始时, p与 t同时指向数组的首地址 * while(*t=c) *用 k 来统计前部星号的个数 * k+; t+; if(k n) *如果 k大于 n,则使 p的前部保留 n个星号,其后的字符依次存入数组 a中 * (while(*p) ai=*(p+kn); i+; p+; ai= 0; *在字符串最后加上结束标识 * 【试题解析】 字符串中前导 *号不能多于 n个,多余的应删除。首先需要通过while循环统计字符串前导 *号的个数,然后通过 if条件语句完成前导 *号的个数和n的比较,如果前导 *号多于 n个,需要把 n个 *号和其余字符重新保留。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1