国家二级C语言机试(操作题)模拟试卷571 (题后含答案及解析)
全部题型 2. 程序填空题 3. 程序修改题 4. 程序设计题
程序填空题
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)【1】,int k){ int i=0;/*********found*********/ while(i<【2】){/*********found*********/ SS[i][k]=【3】;i++;}}main( ){ char x[N][M]={“Create”,”Modi—fy”,”Sort”,”skip”,”Delete”}; int i; printf(“\nThe originalstring\n\n”); for(i=0;i<N;i++)puts(x[i]); printf(“\n”); fun(x,4); printf(“\nThe string afterdeleted:\n\n”); for(i=0;i<N;i++) puts(x[i]); printf(“\n”);}
正确答案:(1)[M] (2)N (3)’\0’
解析:填空1:根据main函数中的函数调用语句,确定函数定义时的形式参数,所以填入[M]。填空2:while循环语句需要对所有字符串进行操作,因此循环条件是i<N。填空3:字符串结尾加入字符串结束标识’\0’。
程序修改题
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+=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));}
正确答案:(1)t=1.0;(2)return(s*2);
解析:该题中,首先检查变量数据类型前后是否一致,因为变量t定义为double型,所以赋值时要赋以实型数值。return(s)是一个数学错误,应该返回return (s*2);。
程序设计题
3. 规定输入的字符串中只包含字母和*号。请编写函数fun,其功能是:使字符串的前导*号不得多于n个,若多于n个,则删除多余的*号;若少于或等于n个,则不做处理。字符串中间和尾部的*号不删除。 例如,字符串中的内容为“*******A*BC*DEF*G****”,若n的值为4,删除后,字符串中的内容应当是“****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 s[81];int n; printf(“Enter a string:\n”); gets(s); print;f(“Enter n:”); Scanf(“%d”,&n); fun(s,n); printf(“The string afterdeleted:\n”); puts(s);}
正确答案: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){a[i]=*(p+k—n);i++;p++;}a[i]=字符串操作函数puts‘\0’; /*在字符串最后加上结束标识*/}}
解析:字符串中前导*号不能多于n个,多余的应删除。首先需要通过while循环统计字符串前导*号的个数,然后通过if条件语句完成前导*号的个数和n的比较,如果前导*号多于n个,需要把n个*号和其余字符重新保留。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论