知ing

最新计算机二级C语言上机试题汇编100套

NCRE研究组 编 / 高等教育出版社

゛Zirro、Y 上传

查看本书

03套: 

程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数fun的功能是重写形参filename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其它学生的数据不变。 

请在程序的下划线处填入正确的内容并把下划线删除使程序得出正确的结果。 

 

注意:源程序存放在考生文件夹下的BLANK1.C中。 

不得增行或删行,也不得更改程序的结构! 

给定源程序: 

#include <stdio.h> 

#define N 5 

typedef struct student { 

long sno; 

char name[10]; 

float score[3]; 

} STU; 

void fun(char *filename, STU n) 

{ FILE *fp; 

/ **********found**********/ 

fp = fopen(__1__, "rb+"); 

/ **********found**********/ 

fseek(__2__, -1L*sizeof(STU), SEEK_END); 

/ **********found**********/ 

fwrite(&n, sizeof(STU), 1, __3__); 

fclose(fp); 

main() 

{ STU t[N]={ {10001,"MaChao", 91, 92, 77}, {10002,"CaoKai", 75, 60, 88}, 

{10003,"LiSi", 85, 70, 78}, {10004,"FangFang", 90, 82, 87}, 

{10005,"ZhangSan", 95, 80, 88}}; 

STU n={10006,"ZhaoSi", 55, 70, 68}, ss[N]; 

int i,j; FILE *fp; 

fp = fopen("student.dat", "wb"); 

fwrite(t, sizeof(STU), N, fp); 

fclose(fp); 

fp = fopen("student.dat", "rb"); 

fread(ss, sizeof(STU), N, fp); 

fclose(fp); 

printf("\nThe original data :\n\n"); 

for (j=0; j<N; j++) 

{ printf("\nNo: %ld Name: %-8s Scores: ",ss[j].sno, ss[j].name); 

for (i=0; i<3; i++) printf("%6.2f ", ss[j].score[i]); 

printf("\n"); 

fun("student.dat", n); 

printf("\nThe data after modifing :\n\n"); 

fp = fopen("student.dat", "rb"); 

fread(ss, sizeof(STU), N, fp); 

fclose(fp); 

for (j=0; j<N; j++) 

{ printf("\nNo: %ld Name: %-8s Scores: ",ss[j].sno, ss[j].name); 

for (i=0; i<3; i++) printf("%6.2f ", ss[j].score[i]); 

printf("\n"); 

 

解题思路: 

本题是考察如何从文件中读出数据,再把结构中的数据写入文件中。 

第一处:从指定的文件中读出数据,所以应填:filename。 

第二处:读取文件fp的最后一条记录,所以应填:fp。 

第三处:再把读出的记录,写入文件fp指定的位置上,所以应填:fp。 

*************************************************** 

给定程序MODI1.C中的函数Creatlink的功能是创建带头结点的单向链表并为各结点数据域赋0m-1的值。 

请改正函数Creatlink中指定部位的错误使它能得出正确的结果。 

注意不要改动main函数不得增行或删行也不得更改程序的结构

给定源程序: 

#include <stdio.h> 

#include <stdlib.h> 

typedef struct aa 

{ int data; 

struct aa *next; 

} NODE; 

NODE *Creatlink(int n, int m) 

{ NODE *h=NULL, *p, *s; 

int i; 

/ **********found***********/ 

p=(NODE )malloc(sizeof(NODE)); 

h=p; 

p->next=NULL; 

for(i=1; i<=n; i++) 

{ s=(NODE *)malloc(sizeof(NODE)); 

s->data=rand()%m; s->next=p->next; 

p->next=s; p=p->next; 

/ **********found***********/ 

return p; 

outlink(NODE *h) 

{ NODE *p; 

p=h->next; 

printf("\n\nTHE LIST :\n\n HEAD "); 

while(p) 

{ printf("->%d ",p->data); 

p=p->next; 

printf("\n"); 

main() 

{ NODE *head; 

head=Creatlink(8,22); 

 

outlink(head); 

解题思路: 

第一处指向刚分配的结构指针,所以应改为:p=(NODE *)malloc(sizeof(NODE)); 

第二处在动态分配内存的下一行语句是,使用临时结构指针变量h保存p指针的初始位置,最后返回不能使用p,是因为p的位置已经发生了变化,所以应改为返回h。 

*************************************************** 

请编写函数fun, 函数的功能是:统计一行字符串中单词的个数,作为函数值返回。一行字符串在主函数中输入规定所有单词由小写字母组成,单词之间由若干个空格隔开一行的开始没有空格。 

注意:部分源程序在文件PROG1.C中。 

请勿改动主函数main和其它函数中的任何内容仅在函数fun的花括号中填入你编写的若干语句。 

给定源程序: 

#include <stdio.h> 

#include <string.h> 

#define N 80 

int fun( char *s) 

main() 

{ char line[N]; int num=0; 

printf("Enter a string :\n"); gets(line); 

num=fun( line ); 

printf("The number of word is : %d\n\n",num); 

NONO(); 

解题思路: 

本题是统计字符串中的单词数。 

1. 利用while循环语句和指针变量,当字符为空格时,则单词数k1。 

2. 循环结束返回k。 

参考答案: 

int fun( char *s) 

int k = 1 ; 

while(*s) { 

if(*s == ' ') k++ ; 

s++ ; 

return k ; 

※※※※※※※※※※※※※※※※※※※※※※※※※ 


查看更多