1、福建省二级 C 语言-3 (1)及答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:20,分数:40.00)1.结构化程序设计的基本结构主要是_。(分数:2.00)A.分支结构、平行结构、循环结构B.分支结构、函数结构、循环结构C.平行结构、选择结构、函数结构D.顺序结构、选择结构、循环结构2.以下不正确的字符串常量是_。(分数:2.00)A.“ “B.“a“C.“abc“D.“abc“3.若已定义 int a, b=5, c=6; ,以下不正确的赋值语句是_。(分数:2.00)A.a=b=c=3;B.a=b+=12;C.a+1=b;D.a=b-c;4.若已定义 int
2、x, y, z; ,执行语句 x=(y=z=2, z+, y+=z); 后,x 的值是_。(分数:2.00)A.2B.3C.5D.85.函数表达式 strlen(“531/0ab“)的值为_。(分数:2.00)A.7B.4C.3D.66.若已定义:int a=3, b=4, c=5; ,则下面表达式中值为 0 的是_。(分数:2.00)A.“a“ else x=2; A B C D (分数:2.00)A.B.C.D.9.以下程序运行时,while 循环体的循环次数为_。 #includestdio.h int main() int i=0; while(i10) if(i3) i+; cont
3、inue; if(i=5) break; i+; printf(“%d/n“, i); return 0; (分数:2.00)A.0B.3C.6D.无限循环,不能确定次数10.以下程序段的功能是_。 int a=4, 0, 2, 3, 1, i, j, t; for(i=0; i4; i+) for(j=i+1; j5; j+) if(aiaj) t=ai; ai=aj; aj=t; (分数:2.00)A.对数组 a 进行顺序比较交换法排序(升序)B.对数组 a 进行顺序比较交换法排序(降序)C.对数组 a 进行选择法排序(升序)D.对数组 a 进行选择法排序(降序)11.以下程序运行结果是_
4、。 #includestdio.h int main() int a33=1, 2, 3, 4, 5, 6, 7, 8, 9, i; for(i=0; i3; i+) printf(“%d“, 10-a2-ii); return 0; (分数:2.00)A.7 5 3B.3 5 7C.9 5 1D.8 4 112.在执行 char str10=“key/0word“; 语句后,strlen(str)的结果是_。(分数:2.00)A.8B.3C.4D.913.以下程序的运行结果是_。 #includestdio.h int main() int fun(int, int); int a=5, b
5、=2, c; c=fun(a, b); printf(“%d,“, c); c=fun(a, b); printf(“%d/n“, c); return 0; fun(int x, int y) static int p=0, t=2; t+=p+1; p=t+x+y; return p; (分数:2.00)A.10,21B.10,10C.10,20D.10,1714.以下程序的运行结果是_。 #includestdio.h int main() int a=5, b=7, c, k; c=a b; k=b2; printf(“c=%d k=%d/n“, c, k); return 0; (分
6、数:2.00)A.c=2 k=14B.c=7 k=28C.c=5 k=28D.c=2 k=2815.若已定义:int*p; int a5=1, 2, 3, 4, 5; int i=3; ,下列赋值语句中,不合理的是_。(分数:2.00)A.p=B.p=a;C.p=D.p=ai;16.以下程序的运行结果是_。 #includestdio.h int main() int a, b; int*p, *q, *temp; a=63; b=36: p= q= temp=p; p=q; q=temp; printf(“%d, %d/n“, a, b); printf(“%d, %d/n“, *p, *q
7、); return 0; A B C D (分数:2.00)A.B.C.D.17.若有以下程序段,则 scanf()函数调用语句中对结构变量成员引用错误的是_。 struct student char na; int age; float score; x, *p; p=(分数:2.00)A.scanf(“%d“, B.scanf(“%f“, C.scanf(“%c“, D.scanf(“%f“, 18.以下程序的运行结果是_。 #includestdio.h struct STU char name10; float score3; ; float av(struct STU*p, int
8、n, int m) int i; float k=0; for(i=0; in; i+) k=k+(p+i)-scorem; return(k/n); int main() struct STU s3=“zhang“, 78, 67, 71, “wang“, 80, 78, 76, “hong“, 76, 85, 90; float ave; ave=av(s, 3, 1); printf(“%6.2f/n“, ave); return 0; (分数:2.00)A.72.00B.79.00C.78.00D.76.6719.下列关于 typedef 叙述错误的是_。(分数:2.00)A.可以使用
9、 typedef 的定义来增加新类型B.typedef 可以定义已存在的各种类型名,但不能用来定义常量或变量C.用 typedef 只是将已存在的类型用一个新的标识符来代表D.使用 typedef 有利于程序的通用和移植20.有如下程序段: #includestdio.h int main() int a=1, b=2, c, d; float x=1.223, y; FILE*fp; fp=fopen(“filel“, “wb+“); fprintf(fp, “%d, %d, %.2f“, a, b, x); rewind(fp); fscanf(fp, “%d, %d, %f“, prin
10、tf(“%d, %d, %.2f“, c, d, y); fclose(fp); return 0; 若文件 filel 已成功打开,下列叙述正确的是_。(分数:2.00)A.仅 fprintf()语句不能正确执行B.仅 fscanf()语句不能正确执行C.输出结果为 1, 2, 1.22D.fprintf()语句和 fscanf()语句都不能正确执行,应该改 fopen()语句中的“wb+“为“w+“二、程序填空题(总题数:1,分数:20.00)(在每对/*/之间填写内容,完成题目的要求)(分数:20.00)(1).以下程序的功能是:将键盘输入的两个两位正整数 a 和 b 合并形成一个四位数
11、的整数 c,合并的方式是:将 a 的十位和个位数依次作为 c 的个位和百位,b 的十位和个位依次作为 c 的千位和十位。 如:输入的 a 数为 23,b 数为 56 则输出的 c 数为:5362 #includestdio.h int/*/ 1/*/() /*/ 2/*/a, b, c; printf(“Input a, b:“); /*/ 3/*/(“%d, %d“, c=b/10*1000+a%10*100+b%10*10+a/10; printf(“c=%d/n“, c); return 0; (分数:10.00)(2).以下程序用以输出以下分数序列前 20 项之和。 (分数:10.00
12、)三、程序改错题(总题数:1,分数:20.00)(修改每对/*/之间存在的错误,完成题目的要求)(分数:20.00)(1).以下程序用以打印所有的“水仙花数”。所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。如:153 是一“水仙花数”,因为 153=1 3 +5 3 +3 3 。 #includestdio.h int main() int i, a, b, c; printf(“Narcissus numbers are:/n“); for(i=100; i1000; i+) a=i/100; /*/ 1 b=i%10/10; /*/ c=i%10; /*/ 2 if(a 3
13、+b 3+c 3=i)/*/ printf(“%5d“, i); return 0; (分数:10.00)(2).以下程序中的函数 fun 用以计算并输出给定 n 个数的方差。方差公式: (分数:10.00)四、编程题(总题数:1,分数:20.00)(补充每对/*/之间的程序段,完成题目的要求)(分数:20.00)(1).程序中的 fun()函数用以完成如下数学表达式: (分数:10.00)_(2).程序中的 fun()函数功能是:根据以下公式求 x 的值(若输入精度为 0.0005,即某项小于 0.0005 时则停止迭代)。 (分数:10.00)_福建省二级 C 语言-3 (1)答案解析(总
14、分:100.00,做题时间:90 分钟)一、选择题(总题数:20,分数:40.00)1.结构化程序设计的基本结构主要是_。(分数:2.00)A.分支结构、平行结构、循环结构B.分支结构、函数结构、循环结构C.平行结构、选择结构、函数结构D.顺序结构、选择结构、循环结构 解析:2.以下不正确的字符串常量是_。(分数:2.00)A.“ “B.“a“C.“abc“ D.“abc“解析:3.若已定义 int a, b=5, c=6; ,以下不正确的赋值语句是_。(分数:2.00)A.a=b=c=3;B.a=b+=12;C.a+1=b; D.a=b-c;解析:4.若已定义 int x, y, z; ,执
15、行语句 x=(y=z=2, z+, y+=z); 后,x 的值是_。(分数:2.00)A.2B.3C.5 D.8解析:5.函数表达式 strlen(“531/0ab“)的值为_。(分数:2.00)A.7B.4C.3 D.6解析:6.若已定义:int a=3, b=4, c=5; ,则下面表达式中值为 0 的是_。(分数:2.00)A.“a“ else x=2; A B C D (分数:2.00)A.B. C.D.解析:9.以下程序运行时,while 循环体的循环次数为_。 #includestdio.h int main() int i=0; while(i10) if(i3) i+; con
16、tinue; if(i=5) break; i+; printf(“%d/n“, i); return 0; (分数:2.00)A.0B.3C.6 D.无限循环,不能确定次数解析:10.以下程序段的功能是_。 int a=4, 0, 2, 3, 1, i, j, t; for(i=0; i4; i+) for(j=i+1; j5; j+) if(aiaj) t=ai; ai=aj; aj=t; (分数:2.00)A.对数组 a 进行顺序比较交换法排序(升序)B.对数组 a 进行顺序比较交换法排序(降序) C.对数组 a 进行选择法排序(升序)D.对数组 a 进行选择法排序(降序)解析:11.以
17、下程序运行结果是_。 #includestdio.h int main() int a33=1, 2, 3, 4, 5, 6, 7, 8, 9, i; for(i=0; i3; i+) printf(“%d“, 10-a2-ii); return 0; (分数:2.00)A.7 5 3B.3 5 7 C.9 5 1D.8 4 1解析:12.在执行 char str10=“key/0word“; 语句后,strlen(str)的结果是_。(分数:2.00)A.8B.3 C.4D.9解析:13.以下程序的运行结果是_。 #includestdio.h int main() int fun(int,
18、 int); int a=5, b=2, c; c=fun(a, b); printf(“%d,“, c); c=fun(a, b); printf(“%d/n“, c); return 0; fun(int x, int y) static int p=0, t=2; t+=p+1; p=t+x+y; return p; (分数:2.00)A.10,21 B.10,10C.10,20D.10,17解析:14.以下程序的运行结果是_。 #includestdio.h int main() int a=5, b=7, c, k; c=a b; k=b2; printf(“c=%d k=%d/n“
19、, c, k); return 0; (分数:2.00)A.c=2 k=14B.c=7 k=28C.c=5 k=28D.c=2 k=28 解析:15.若已定义:int*p; int a5=1, 2, 3, 4, 5; int i=3; ,下列赋值语句中,不合理的是_。(分数:2.00)A.p=B.p=a;C.p=D.p=ai; 解析:16.以下程序的运行结果是_。 #includestdio.h int main() int a, b; int*p, *q, *temp; a=63; b=36: p= q= temp=p; p=q; q=temp; printf(“%d, %d/n“, a,
20、b); printf(“%d, %d/n“, *p, *q); return 0; A B C D (分数:2.00)A.B. C.D.解析:17.若有以下程序段,则 scanf()函数调用语句中对结构变量成员引用错误的是_。 struct student char na; int age; float score; x, *p; p=(分数:2.00)A.scanf(“%d“, B.scanf(“%f“, C.scanf(“%c“, D.scanf(“%f“, 解析:18.以下程序的运行结果是_。 #includestdio.h struct STU char name10; float s
21、core3; ; float av(struct STU*p, int n, int m) int i; float k=0; for(i=0; in; i+) k=k+(p+i)-scorem; return(k/n); int main() struct STU s3=“zhang“, 78, 67, 71, “wang“, 80, 78, 76, “hong“, 76, 85, 90; float ave; ave=av(s, 3, 1); printf(“%6.2f/n“, ave); return 0; (分数:2.00)A.72.00B.79.00C.78.00D.76.67 解析
22、:19.下列关于 typedef 叙述错误的是_。(分数:2.00)A.可以使用 typedef 的定义来增加新类型 B.typedef 可以定义已存在的各种类型名,但不能用来定义常量或变量C.用 typedef 只是将已存在的类型用一个新的标识符来代表D.使用 typedef 有利于程序的通用和移植解析:20.有如下程序段: #includestdio.h int main() int a=1, b=2, c, d; float x=1.223, y; FILE*fp; fp=fopen(“filel“, “wb+“); fprintf(fp, “%d, %d, %.2f“, a, b, x
23、); rewind(fp); fscanf(fp, “%d, %d, %f“, printf(“%d, %d, %.2f“, c, d, y); fclose(fp); return 0; 若文件 filel 已成功打开,下列叙述正确的是_。(分数:2.00)A.仅 fprintf()语句不能正确执行B.仅 fscanf()语句不能正确执行C.输出结果为 1, 2, 1.22 D.fprintf()语句和 fscanf()语句都不能正确执行,应该改 fopen()语句中的“wb+“为“w+“解析:二、程序填空题(总题数:1,分数:20.00)(在每对/*/之间填写内容,完成题目的要求)(分数:
24、20.00)(1).以下程序的功能是:将键盘输入的两个两位正整数 a 和 b 合并形成一个四位数的整数 c,合并的方式是:将 a 的十位和个位数依次作为 c 的个位和百位,b 的十位和个位依次作为 c 的千位和十位。 如:输入的 a 数为 23,b 数为 56 则输出的 c 数为:5362 #includestdio.h int/*/ 1/*/() /*/ 2/*/a, b, c; printf(“Input a, b:“); /*/ 3/*/(“%d, %d“, c=b/10*1000+a%10*100+b%10*10+a/10; printf(“c=%d/n“, c); return 0;
25、 (分数:10.00)解析:main int scanf(2).以下程序用以输出以下分数序列前 20 项之和。 (分数:10.00)解析:sum=0 a/b t三、程序改错题(总题数:1,分数:20.00)(修改每对/*/之间存在的错误,完成题目的要求)(分数:20.00)(1).以下程序用以打印所有的“水仙花数”。所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。如:153 是一“水仙花数”,因为 153=1 3 +5 3 +3 3 。 #includestdio.h int main() int i, a, b, c; printf(“Narcissus numbers are
26、:/n“); for(i=100; i1000; i+) a=i/100; /*/ 1 b=i%10/10; /*/ c=i%10; /*/ 2 if(a 3+b 3+c 3=i)/*/ printf(“%5d“, i); return 0; (分数:10.00)解析:b=i/10%10; if(a*a*a+b*b*b+c*c*c=i)(2).以下程序中的函数 fun 用以计算并输出给定 n 个数的方差。方差公式: (分数:10.00)解析:double fun(double x, int n) double sum=0.0, ave, sa=0.0; sa+=(xi-ave)*(xi-ave
27、);四、编程题(总题数:1,分数:20.00)(补充每对/*/之间的程序段,完成题目的要求)(分数:20.00)(1).程序中的 fun()函数用以完成如下数学表达式: (分数:10.00)_正确答案:()解析:double y; if(x=2) if(x2) y=fabs(1.23*x-1.79); else y=exp(x)+pow(x, 3); else y=cos(x); return y;(2).程序中的 fun()函数功能是:根据以下公式求 x 的值(若输入精度为 0.0005,即某项小于 0.0005 时则停止迭代)。 (分数:10.00)_正确答案:()解析:double s; float n, t, p; t=1; p=0; n=1.0; s=1.0; while(fabs(s)=eps) p+=s; t=n/(2*n+1); s*=t; n+; p=p*2; return p;