1、国家二级( C语言)机试模拟试卷 346及答案与解析 一、程序填空题( 30分) 1 程序通过定义学生结构体变量,存储了学生的学号、姓名和 3门课的成绩。所有学生数据均以二进制方式输出到 student dat文件中。函数 fun的功能是从指定文件中找出指定学号的学生数据,读入此学生数据,对该生的分数进行修改,使每门课的分数加 3分,修改后重写文件中该学生的数据。即用该学生的新数据覆盖原数据,其他学生数据不变;若找不到,则什么都不做。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANKl C中。 不得增行或删行,也不得更改程序的
2、结构 ! #include #define N 5 typedef struct student long sno; char name10; float score3; STU; void fun(char *filename, long sno) FILE *fp; STU n; int i; fp = fopen(filename,“rb+“); /*found*/ while (!feof(【 1】 ) fread( /*found*/ if (n.sno【 2】 sno) break; if (!feof(fp) for (i=0; i #include #define MAXLIN
3、E 20 fun (char *pstr6) int i, j ; char *p ; for (i = 0 , i 0) p = *(pstr + i); /*found*/ *( pstr+i)=pstr+j; *(pstr + j) = p ; main() int i ; char *pstr6, str6MAXLINE ; for(i = 0; i #include #include void fun(char *s,int num) NONO() /* 请在此函数内打开文件,输入测试数据,调用 fun 函数,输出数据,关闭文件。 */ char s10 ; FILE *rf, *w
4、f ; int i = 0 ; rf = fopen(“in.dat“,“r“); wf = fopen(“out.dat“,“w“); while(i 10) fgets(s,10,rf); s7 = 0 ; fun(s,7); fprintf(wf, “%sn“, s); i+ ; fclose(rf); fclose(wf); main() char s10; printf(“输入 7个字符的字符串 :“); gets(s); fun(s,7); printf(“n%s“,s); NONO(); 国家二级( C语言)机试模拟试卷 346答案与解析 一、程序 填空题( 30分) 1 【正确
5、答案】 fp = fp 【试题解析】 第一空: “while (!feof(_1_)”是在文件没有达到文件尾的情况不断读取文件内容,文件状态检测函数 feof的调用形式为: feof(fp),其中 fp为文件指针,故第一空处应为 “fp”。 第二空:题干要求找到指定学号的学生数据, “if (n.sno_2_sno)”是比较读取出来的 n学生的学号和指定的学好 sno是否相等,故第二空处应为 “=”。 第三空:此处是补充 fseek函数的参数, fseek的调用形式是: fseek(fp, offset, position),其中第一个参数是文件型指针,故第三空处应填文件型指针变量 “fp”。
6、 二、程序修改题( 30分) 2 【正确答案】 for (j=i+1; j6; j+) *( pstr+i)=*( pstr+j); 【试题解析】 ( 1) C语言中, for语句形式是: for(表达式 1; 表达式 2; 表达式 3) 循环体语句。 因此第一个标识下, for使用错误,应该为 “for (j=i+1; j6; j+)”。 ( 2) if语句后的复合语句的功能是把 “*(pstr+i)”中和 “*(pstr+j)”中的地址进行交换,而 “*(pstr+i)=pstr+j;”中 “pstr+j;”并不是字符串的地址,所以第二个标识下“*( pstr+i)=pstr+j;”改为
7、“*( pstr+i)=*( pstr+j);”。 三、程序设计题( 40分) 3 【正确答案】 char t; int i,j; for(i=1;inum-2;i+) /对 n个元素进行循环选择 for(j=i+1;jnum-1;j+) if(sisj) /将 stri设为最大值,和剩下的 j n-1进行比较 t=si; si=sj; sj=t; 【试题解析】 进入 fun函数,根据前面的分析: 选择排序法中的降序排序,首先从数组中挑选一个最大的元素,把它和第一个元素交换,接着从剩下的 num-1个元素中再挑出一个最大的元素,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。