国家二级(C语言)机试模拟试卷67 (题后含答案及解析)
题型有:1. 程序填空题 2. 程序修改题 3. 程序设计题
程序填空题(30分)
1. 请补充函数fun( ),该函数的功能是:把ASCII码为奇数的字符从字符串str中删除,结果仍然保存在字符串str中。字符串str从键盘输入,其长度作为参数传入函数fun( )。 例如,输入“abcdef”,输出“bdf”。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun( )的横线上填入所编写的若干表达式或语句。 试题程序: #include <stdio.h> #define N 80 void fun(char s[],int n) { int i, j; j=0; for(i=0;【 】;i++) { if(【 】) s [j++]-s [i]; }【 】; } main ( ) { int i=0, strlen=0; char str [N]; clrscr
( ); printf (“\\nInput a string: \\n”); gets (str); while (str [i] !=‘\\0’) { strlen++; i++; } fun(str, strlen); printf(“\\n*** display string ***\\n”); puts (str); }
正确答案:i<ns[i]%2=0s[j]= ‘\\0’
解析:第一空:变量n为字符串的长度,所以字符数组的下标的取值范甲是从0到n-1。第二空:如果当前字符的ASCII码对2取余等于0,就说明这个字符的ASCII码为偶数,故不能删除,而是将它存于字符串s中。第三空:通过保留ASCII码为偶数的字符的力法,来实现删除ASCII码为奇数的字符的目的。处理结束后,还要在字符串s的最后加上结束标记符’\\0’。
程序修改题(30分)
2. 下列给定程序中,函数fun( )的功能是:用递归算法计算斐波拉契级数列中第n项的值。从第一项起,斐波`拉契级数序列为1, 1,2,3,5,8,13,21,……例如,若给n输入7, 该项的斐波拉契级数值为13。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include <stdio.h> long
fun(int g) { /*************found**************/ switch(g); {case 0:return 0; switch(g) case 1; case 2:return 1; } return (fun(g-1)+fun(g-2)); } main( ) { long fib; int n; printf(“Input n:”);scanf(“%d”,&n); printf(“n-%d\\n”,n); fib=fun(n); printf(“fib=%d\\D\\n”,fib); }
正确答案:(1)错误:switch(g); 正确:去掉分号(2)错误:case 1;case 2:return 1: 正确:case 1:case 2:return 1;
解析:C语言中,Switch语句之后不能有分号,并且Case语句常量后应用的是冒号。
程序设计题(40分)
3. 已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。请编写函数fun( ),该函数的功能是;找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。已给出函数的首部,请完成该函数。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。 试题程序: #include<stdio.h> #include<string.h> #include<conio.h> #define N 10 typedef struct ss /*定义结构体*/ { char num[10]; int s; } STU; fun(STU a[], STU *s) { } main ( ) { STU
a[N]={{ “A01”,81},{ “A02”,89}, { “A03”,66},{ “A04”,87},{ “A05”,77}, { “A06”,90},{ “A07”,79}, { “A08”,61}, { “A09”,80},{ “A10”,71}},m; int i; clrscr ( ); printf(“*****The original data*****”); for (i=0; i<N; i++) printf(“No=%s Mark=%d\\n”, a[i].hum, a[i].s); fun (a, &m); printf (“*****THE RESULT*****\\n”); printf(“The top :%s, %d\\n”,m.num, m.s); }
正确答案:fun(STU a[], STU *s) { int i; *s=a[0]; for (i=0; i<N; i++) /*找出成绩最高的学生记录*/ if (s->s<a [i].s) *s==a [i]; }
解析:本题的流程是这样的,先使s指向第1个学生,我们的题干目的是找出分数最高的学生,所以if语句的条件是 s->s<a[i].s。此外,在做本题时,我们应该熟练掌握“指向运算符”和“成员运算符”的相关知识。题中“s->s”也可换成“(*s).s”。
因篇幅问题不能全部显示,请点此查看更多更全内容