//C程序设计第四版(谭浩强)
//章节:第十章 对文件的输入输出
//题号:10.7
//题目:将第6题已排序的学生成绩文件进行插入处理。插入一个学生的3门课程成绩,
//程序先计算新插入学生的平均成绩,然后将它按成绩高低顺序插入,插入后建立一个新文件。
#include <stdio.h>
#include <stdlib.h>
#define N 5
struct student
{
int num;
char name[20];
float score[3];
float aver;
}stu[N+1],stu0;
int main()
{
FILE *fp1,*fp2;
int i,j,k;
if((fp1=fopen("stud_sort","rb"))==NULL) //打开文件stud_sort
{
printf("cannot open stud_sort!\n");
exit(0);
}
printf("the original date:\n");
printf("num name score1 score2 score3 average\n");
for(i=0;i<N;i++)
{
fread(&stu[i],sizeof(struct student),1,fp1); //先读取原来的数据,并将其显示在屏幕上
printf("%-2d%5s%7.1f%7.1f%7.1f%7.1f\n",stu[i].num,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].aver);
}
fclose(fp1);
printf("请输入一个学生学号,姓名,3门课程成绩(以空格隔开)\n");
scanf("%d%s%f%f%f",&stu[N].num,stu[N].name,&stu[N].score[0],&stu[N].score[1],&stu[N].score[2]);
stu[N].aver=(stu[N].score[0]+stu[N].score[1]+stu[N].score[2])/3.0;
for(i=0;i<N;i++) //选择排序法
{
k=i;
for(j=i+1;j<N+1;j++)
if(stu[j].aver<stu[k].aver)
k=j;
if(i!=k)
{
stu0=stu[i];
stu[i]=stu[k];
stu[k]=stu0;
}
}
if((fp2=fopen("stud_sort_new","wb"))==NULL)
{
printf("cannot open the file stud_sort_new!\n");
exit(0);
}
for(i=0;i<N+1;i++)
{
if(fwrite(&stu[i],sizeof(struct student),1,fp2)!=1)
printf("file write error\n");
}
fclose(fp2);
if((fp2=fopen("stud_sort_new","rb"))==NULL) //重新打开文件stud_sort_new
{
printf("cannot open the file stud_sort_new!\n");
exit(0);
}
printf("\nthe new sorted data:\n");
printf("num name score1 score2 score3 average\n");
for(i=0;i<N+1;i++)
{
fread(&stu[i],sizeof(struct student),1,fp2);
printf("%-2d%5s%7.1f%7.1f%7.1f%7.1f\n",stu[i].num,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].aver);
}
fclose(fp2);
}
10.7将第6题已排序的学生成绩文件进行插入处理。插入一个学生的3门课程成绩,程序先计算新插入学生的平均成绩,然后将它按成绩高低顺序插入,插入后建立一个新文件。
最新推荐文章于 2022-06-12 20:07:10 发布