1、二级 C 语言-291 (1)及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.请补充函数 proc(),该函数可以统计一个长度为 n 的字符串在另一个字符串中出现的次数。 例如,假定输入的字符串为:asd ascasdfg asd as as mlosd,子字符串为 asd,则应输出 3。 注意:部分源程序给出如下。 请勿改动函数 main()和其他函数中的任何内容,仅在函数 proc()的横线上填入所编写的若干表达式或语句。 试题程序: #includestdlib.h #includestdio.h #includestring.h
2、#includeconio.h int proc(char *str, char *sub) int n; char *p, *r; 1; while(*str) p=str; r=sub; while(*r) if( 2) r+; p+; else break; if( 3) n+; str+; return n; void main() char str81, sub3; int n; system(“CLS“); printf(“输入主字符串:“); gets(str); printf(“输入子字符串:“); gets(sub); puts(str); puts(sub); n=proc
3、(str, sub); printf(“n=%d/n“, n); (分数:30.00)二、程序改错题(总题数:1,分数:40.00)2.下列给定程序中,函数 proc()的功能是:应用递归算法求某数 a 的平方根。求平方根的迭代公式如下:x1=(x0+a/x0)/2 例如,3 的平方根为 1.732051。 请修改程序中的错误,使它能得出正确的结果。 注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。 试题程序: #includemath.h #includestdio.h /*found* proc(double a, double x0) double x1, y;
4、x1=(x0+a/x0)/2.0; /*found* if(fabs(x1-x0)0.00001) y=proc(a, x1); else y=x1; return y; void main() double s; printf(“Enter s:“); scanf(“%1f“, printf(“The square root of %1f is %1f/n“, s, proc(s, 1.0); (分数:40.00)_三、程序设计题(总题数:1,分数:30.00)3.请编写函数 proc(),其功能是:计算并输出下列多项式值。 S=(1+1/2)+(1/3+1/4)+(1/(2n-1)+1/2
5、n) 例如,若输入 10,则输出为 S=3.597740。 n 的值要求大于 1 但不大于 100。 注意:部分源程序给出如下。 请勿改动函数 main()和其他函数中的任何内容,仅在函数 proc()的花括号中填入所编写的若干语句。 试题程序: #includestdio.h double proc(int n) void main() int n; double s; printf(“/nInput n:“); scanf(“%d“, s=proc(n); printf(“/ns=%f/n“, s); (分数:30.00)_二级 C 语言-291 (1)答案解析(总分:100.00,做题时
6、间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.请补充函数 proc(),该函数可以统计一个长度为 n 的字符串在另一个字符串中出现的次数。 例如,假定输入的字符串为:asd ascasdfg asd as as mlosd,子字符串为 asd,则应输出 3。 注意:部分源程序给出如下。 请勿改动函数 main()和其他函数中的任何内容,仅在函数 proc()的横线上填入所编写的若干表达式或语句。 试题程序: #includestdlib.h #includestdio.h #includestring.h #includeconio.h int proc(char *str
7、, char *sub) int n; char *p, *r; 1; while(*str) p=str; r=sub; while(*r) if( 2) r+; p+; else break; if( 3) n+; str+; return n; void main() char str81, sub3; int n; system(“CLS“); printf(“输入主字符串:“); gets(str); printf(“输入子字符串:“); gets(sub); puts(str); puts(sub); n=proc(str, sub); printf(“n=%d/n“, n); (
8、分数:30.00)解析:n=0 *r=*p *r=“/0“解析 由函数 proc 可知,变量 n 为字符串 str 中子字符串的个数,其初始值为 0,因此,第一处填“n=0”。字符指针变量 p 和 r 分别指向字符串和子字符串,要对其指向的每一个字符进行比较,因此,第二处填“*r=*p”。每比较完一次,要检查指针 r 是否指向子字符串的结束位置,如果是说明字符串中包含一个子字符串,因此,第三处填“*r=“/0“”。二、程序改错题(总题数:1,分数:40.00)2.下列给定程序中,函数 proc()的功能是:应用递归算法求某数 a 的平方根。求平方根的迭代公式如下:x1=(x0+a/x0)/2
9、例如,3 的平方根为 1.732051。 请修改程序中的错误,使它能得出正确的结果。 注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。 试题程序: #includemath.h #includestdio.h /*found* proc(double a, double x0) double x1, y; x1=(x0+a/x0)/2.0; /*found* if(fabs(x1-x0)0.00001) y=proc(a, x1); else y=x1; return y; void main() double s; printf(“Enter s:“); scanf(
10、“%1f“, printf(“The square root of %1f is %1f/n“, s, proc(s, 1.0); (分数:40.00)_正确答案:()解析:(1)错误:proc(double a, double x0) 正确:double proc(double a, double x0) (2)错误:if(fabs(x1-x0)0.00001) 正确:if(fabs(x1-x0)=0.00001) 解析 由主函数中的 proc 函数调用可知,函数 proc 应该有一个double 型的返回值。因此,“proc(double a, double x0)”应改为“double
11、proc(doubk a, double x0)”;由 double 型数据的精确值可知,“if(fabs(x1-x0)0.00001)”应改为“if(fabs(x1-x0)=0.00001)”。三、程序设计题(总题数:1,分数:30.00)3.请编写函数 proc(),其功能是:计算并输出下列多项式值。 S=(1+1/2)+(1/3+1/4)+(1/(2n-1)+1/2n) 例如,若输入 10,则输出为 S=3.597740。 n 的值要求大于 1 但不大于 100。 注意:部分源程序给出如下。 请勿改动函数 main()和其他函数中的任何内容,仅在函数 proc()的花括号中填入所编写的若
12、干语句。 试题程序: #includestdio.h double proc(int n) void main() int n; double s; printf(“/nInput n:“); scanf(“%d“, s=proc(n); printf(“/ns=%f/n“, s); (分数:30.00)_正确答案:()解析:double proc(int n) int i; double s=0.0; /s 是和的变量,因此其初始值为 0 for(i=1; i=n; i+) /从第 1 项到第 n 项 s=s+(1.0/(2*i-1)+1.0/(2*i); /根据题目的要求把分子、分母转化为符合题意的类型 return s; /最后把其值返回到主函数 解析 首先定义一个变量来存放表达式的和,根据题目中提供的多项式,通过 n 次循环来求出 n 项的和。最后把所求得的和返回到主函数当中。