第七次实验~

part 1:

验证性实验2

对line29作修改后:

#include <stdio.h> 
#include <stdlib.h>

#define N 10

// 定义一个结构体类型STU 
typedef struct student {
    int num;
    char name[20];
    int score;
}STU;

int main() {
    STU st, stmax, stmin;
    int i;
    FILE *fp;
    
    // 以只读文本方式打开文件file1.dat 
    fp = fopen("file1.dat", "r");
    if( !fp ) {  // 如果打开失败,则输出错误提示信息,然后退出程序 
        printf("fail to open file1.dat\n");
        exit(0);
    }
    
    stmax.score = 0;    // 先假定最高分是0,后面如发现比当前最高分还高的分数,就更新最高分 
    stmin.score = 100;    // 先假定最低分是100分,后面如发现比当前最低分更低的分数,就更新最低分 
    
    while(!feof(fp)) {
        fscanf(fp, "%d %s %d", &st.num, st.name, &st.score);  // 从fp指定的文件中格式化读取一个学生信息
        
        if(st.score > stmax.score)
            stmax = st;
        else if(st.score < stmin.score)
            stmin = st; 
    } 
    
    fclose(fp);
    
    printf("最高分学生信息: %5d%15s%5d\n", stmax.num, stmax.name, stmax.score);
    printf("最低分学生信息: %5d%15s%5d\n", stmin.num, stmin.name, stmin.score);

    return 0;
}

运行结果完全正确。

 

对比验证性实验3与验证性实验4:

 

运行结果如上。

比较二进制文件与文本文件的区别:

(1)能存储的数据类型不同:

文本文件只能储存char型字符变量。

二进制文件可以存储char/int/short/long/float/....各种变量值。

(2)每条数据的长度:

文本文件每条数据通常是固定长度的。

二进制文件每条数据不固定、

(3)读取的软件不同。

 

part 2:

void input(STU s[], int n) {
    int i;
    FILE *fp;
    fp=fopen("examinee.txt","r");
    if(!fp){
        printf("fail to open examinee.txt\n");
        exit(0);
    }
    for(i=0;i<N;i++){
        fscanf(fp,"%ld %s %f %f",&s[i].id,s[i].name,&s[i].objective,&s[i].subjective);
    } 
    fclose(fp);
}

// 输出考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级
// 不仅输出到屏幕上,还写到文本文件result.txt中 
void output(STU s[], int n) {
int i;
FILE *fout;
fout=fopen("result.txt","w");
if(!fp){
printf("fail to open result.txt\n");
exit(0);
}
for(i=0;i<N;i++){
        printf("%ld,%s,%f,%f,%f,%s\n",s[i].id,s[i].name,s[i].objective,s[i].subjective,s[i].sum,s[i].level);
        fprintf(fout,"%ld,%s,%f,%f,%f,%s\n",s[i].id,s[i].name,s[i].objective,s[i].subjective,s[i].sum,s[i].level);
    }
    fclose(fout);
}

// 对考生信息进行处理:计算总分,排序,确定等级
void process(STU s[], int n) {
     int i,m,p,j;
    STU temp;
    for(i=0;i<N;i++){
        s[i].sum=s[i].objective+s[i].subjective;
    }   
    for(m=0;m<N-1;m++){
        for(p=0;p<N-1-m;p++){
            if(s[p].sum<s[p+1].sum){
                temp=s[p];
                s[p]=s[p+1];
                s[p+1]=temp;
            }
        }
    }
    for(j=0;j<N;j++){
        if(s[j].sum>=s[N*0.1].sum){
            strcpy(s[j].level,"优秀");    
        }
        else if(s[j].sum>s[N*0.5].sum){
            strcpy(s[j].level,"合格");
        }
        else{
            strcpy(s[j].level,"不合格"); 
        }
             
        }
        
        
    } 
    
}

 

这次实验完成比较仓促,总结没有太多,只是打开文件的时候遇到些麻烦,马上考试了大家加油!

 

https://www.cnblogs.com/rosalyn/p/11070695.html

https://www.cnblogs.com/wznn/

https://www.cnblogs.com/fanlock/p/11074534.html

 

posted @ 2019-06-24 19:44  yzxyzx  阅读(110)  评论(2编辑  收藏  举报