国家二级C语言机试(操作题)模拟试卷588 (题后含答案及解析)
全部题型    2. 程序填空题 3. 程序修改题 4. 程序设计题
程序填空题
1. 下列给定程序中,函数fun的功能是:计算如下公式前n项的和,并作为函数值返回。    例如,当形参n的值为10时,函数返回值为9.612558。    请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。    注意:部分源程序给出如下。    不得增行或删行,也不得更改程序的结构!    试题程序:#include<stdio.h>double fun(int n){ int i;double s,t;/*********found*********/  s=【1】;/*********found*********/  for(i=1; i<【2】; i++)  {t=2.0*i;/*********found*********/    S=S+(2.0*i一1):jc(2.0*i+1)/【3】;    }    return s;}void main(  ){  int n=一1;    while(rl<0)    {printf(Please input(n>0):);    scarlf(%d,&n);}  printf(\nThe result is:%f\n,fun(i1));}
正确答案:(1)0.0 (2)n (3)(t*t)
解析:本题考查:变量初始化操作,需注意该变量是用做累加器还是累乘器;for循环语句。填
空1:程序开始定义了变量s,但没有对其进行初始化,根据公式及后面的程序可知变量s用来存放公式的前n项和,因此该变量应初始化为0.0。填空2:通过for循环语句将表达式各项进行累加,结果存于变量s中,循环变量i的取值范围为1一n。填空3:根据题目要求确定表达式通项。前面已定义t=2.0*i,因此此空应填(t*t)。程序要求计算表达式的值时,一般都设定一个变量s并赋初值。如果s用来存放表达式的和,则赋初值为0;如果s用来存放表达式的积,则赋初值为1。 
程序修改题
2. 下列给定程序中函数fun的功能是:统计substr所指的字符串在str所指的字符串中出现的次数。    例如,若字符串为aaas 1kaaas,子字符串为as,则应输出2。    请改正程序中的错误,使它能得出正确的结果。    注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!试题程序:#include<stdio.h>int fun(char* str,char*sub-str){  int i,j,k,num=0;/*********found*********/    for(i=0,str[i],i++)    for(j=i,k=0;substr[k]==str[j];k++,J++)/*********found*********/    If(substr[k+1]==\0)    {num++;    break;    }    return num;}main(  ){  char str[80],substr[80];  printf(Input a string:);  gets(str);  printf(Input a substring:);  gets(substr);  printf(%d\n,fun(str,substr));}
正确答案:(1)for(i=0;str[i];i++)(2)if(substr[k+1]:=\0)
解析:本题考查:for循环语句的格式,for循环语句使用最为灵活,其一般形式为for(表达式1;表达式2;表达式3),注意表达式之间使用“;”相隔;if条件语句的格式,其中if关键字需要区别大小写,不能混淆使用。关键字是由C语言规定的具有特定意义的字符串,也称为保留字。用户定义的标识符不应与关键字相同,并且关键字应小写。先看循环条件for(i=0,str[i],i++),不难发现此处for循环语句的格式有误,其中表达式之间应以“;”相隔;同时很容易发现if条件语句处的关键字书写错误。 
程序设计题
3. 编写函数fun,其功能是:根据以下公式求π的值(要求精度0.0005,即某项小于0.0005时停止迭代)。    程序运行后,若输入精度0.0005,则程序应输出为3.140578。    注意:部分源程序给出如下。    请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。  试题程序:#include<Stdio.h>#include<conio.h>#include<math.h>double fun(double eps){}void main(  ){    double x;    printf(Input eps:);    Scanf(%1f,&x);    printf(\neps=%1f,PI=%if\n,x,fun(x))
;}
正确答案:double fun(double eps){double s=0.0,s1=1.0;int n=1;while(s1>=eps)    /*当某项大于精度要求时,继续求下一项*/s=s+s1;    /*求和*/{ s1=s1* n/(2*n+1);/*求多项式的每一项*/n++;}return 2* s;}
printf函数具有计算功能吗解析:本题考查:迭代法求给定多项式的值。迭代算法是让计算机对一组指令(或一定步骤)进行重复执行,在每次执行这组指令(或这些步骤)时,都从变量的原值推出它的一个新值。需要注意变量的数据类型以及赋初值操作。首先应该定义double类型变量,并且赋初值,用来存放多项式的某一项和最后的总和。从第二项开始以后的每一项都是其前面一项乘以n/(2*n+1),程序中用s1来表示每一项,s表示求和后的结果。需注意s1和s的初值都为1.0,因为循环变量从第二项开始累加。