国家二级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]={CreateModi—fySortskipDelete};    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小时内删除。