1、二级 C 语言-182 及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.下列给定程序中,函数 fun 的功能是:计算如下公式前 n 项的和,并作为函数值返回。 (分数:30.00)二、程序改错题(总题数:1,分数:30.00)2.下列给定程序中,函数 fun 的功能是:统计 substr 所指的字符串在 str 所指的字符串中出现的次数。 例如,若字符串为 aaas lkaaas,子字符串为 as,则应输出 2。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! 试题程序:
2、 #includestdio.h int fun(char*str,char*substr) int i,j,k,num=0; /*found*/ for(i=0,stri,i+) for(j=i,k=0;substrk=strj;k+,j+) /*found*/ If(substrk+1=“/0“) num+; break; return num; main() char str80,substr80; printf(“Input a string:“); gets(str); printf(“Input a substring:“); gets(substr); printf(“%d/n“
3、,fun(str,substr); (分数:30.00)_三、程序设计题(总题数:1,分数:40.00)3.编写函数 fun,其功能是:根据以下公式求 的值(要求精度 0.0005,即某项小于 0.0005 时停止迭代)。(分数:40.00)_二级 C 语言-182 答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.下列给定程序中,函数 fun 的功能是:计算如下公式前 n 项的和,并作为函数值返回。 (分数:30.00)解析:0 n sf(t*t-1)/(t*t) 考点 本题关键字有:变量赋初值;for 循环语句;表达式求值。一般用一个变量
4、求表达式的值,若该变量存放各项之和,则赋初值 0;若存放各项之积,则赋初值 1。 解析 填空 1:变量 s 用来存放公式的前 n 项和,因此给 s 赋初值为 0。 填空 2:表达式各项的和通过 for 循环语句存于变量 s 中,变量 i 的取值为 1-n。 填空 3:根据题目要求确定表达式通项,因此应填(t*t)。二、程序改错题(总题数:1,分数:30.00)2.下列给定程序中,函数 fun 的功能是:统计 substr 所指的字符串在 str 所指的字符串中出现的次数。 例如,若字符串为 aaas lkaaas,子字符串为 as,则应输出 2。 请改正程序中的错误,使它能得出正确的结果。 注
5、意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h int fun(char*str,char*substr) int i,j,k,num=0; /*found*/ for(i=0,stri,i+) for(j=i,k=0;substrk=strj;k+,j+) /*found*/ If(substrk+1=“/0“) num+; break; return num; main() char str80,substr80; printf(“Input a string:“); gets(str); printf(“Input a s
6、ubstring:“); gets(substr); printf(“%d/n“,fun(str,substr); (分数:30.00)_正确答案:()解析:for(i=0;stri;i+) if(substrk+1=“/0“) 考点 本题关键字有:for 循环语句的格式;if 条件语句。for 语句一般形式为 for(表达式 1;表达式 2;表达式 3),表达式之间使用分号隔开,if 关键字区分大小写。关键字也称保留字,是由 C 语言规定的具有特定意义的字符串,并且关键字应小写,用户定义的标识符不应与关键字相同。 解析 (1)for 循环语句的表达式之间应以“;”相隔。 (2)if 条件语句
7、的 If 错误,应改为小写。三、程序设计题(总题数:1,分数:40.00)3.编写函数 fun,其功能是:根据以下公式求 的值(要求精度 0.0005,即某项小于 0.0005 时停止迭代)。(分数:40.00)_正确答案:()解析:double fun(double eps) double s=1.0,s1=1.0; int n=1; while(s1=eps) /*当某项大于精度要求时,继续求下一项*/ s1=s1*n/(2*n+1); /*求多项式的每一项*/ s=s+s1; /*求和*/ n+; return 2*s; 考点 本题关键字有:迭代法求给定多项式的值。迭代算法是让计算机重复执行一组指令(或一定步骤),在每次执行时,都从变量的原值推出它的一个新值。 解析 多项式的某一项和最后的总和来存放用两个 double 类型变量,循环从第二个开始,备项与各项之和初始化为 1、0,从第二项开始后一项是前一项与 n/(2*n+1)的乘积。