当前位置: 首页 > article >正文

【C语言】文件、结构体综合应用:小型学生成绩管理

功能:
读取学生人数;
依次输入学生的学号、姓名、多个学科成绩;
按照总成绩进行排序,总成绩相同分别按科目一、科目二、科目三成绩进行比较;
计算各科目的平均分,并输出学生成绩单到文件file.txt中。

最终成绩单:

在这里插入图片描述

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
/*	功能:文件与结构体的应用 
	时间:2024年10月 
	地点:贤者楼129 
	作者:LChen
*/
// 5个学生,每个学生三门成绩,计算平均分并存储查看 
// 按照学生总成绩进行排序,成绩相同时依次比较第一科,第二科和第三科 
typedef struct student{
	int ID;				// 学号 
	char name[20];		// 姓名  
	double score0;		// 总成绩 
	double score1;		// 科目一 
	double score2;
	double score3;		
}Student; 
 
int main() {
	
	FILE *fp;			// 定义文件指针 
	char ch;
	
	// 将数据写入文件中 
	fp=fopen("E:\\Desktop\\file2.txt","w"); //w为写权限 
	if(!fp){			// 文件打开失败结束程序 
		printf("can not open file\n");
		exit(1);
	}
	
	int i,j;
	Student temp,stu[5];		// 定义 
	double Score1=0,Score2=0,Score3=0; 
	
	for(i=0;i<5;i++){
		scanf("%d %s %lf %lf %lf",&stu[i].ID,stu[i].name,&stu[i].score1,&stu[i].score2,&stu[i].score3);
		stu[i].score0=stu[i].score1+stu[i].score2+stu[i].score3; 	//计算总成绩 
		Score1+=stu[i].score1;	// 单科总分 
		Score2+=stu[i].score2;
		Score3+=stu[i].score3;
	}
	
	for(i=0;i<4;i++) {			// 共进行n-1趟排序
		for(j=4;j>i;j--) {		// 递减循环,从后往前比较
            if(stu[j].score0>stu[j-1].score0) {			//优先按照总成绩排序 
                temp=stu[j-1];
                stu[j-1]=stu[j];
                stu[j]=temp;
            }
            else if(stu[j].score0==stu[j-1].score0) {
	            if(stu[j].score1>stu[j-1].score1) {		//其次比较第一科目成绩  
	                temp=stu[j-1];
	                stu[j-1]=stu[j];
	                stu[j]=temp;
	            }
	            else if(stu[j].score1==stu[j-1].score1) {
	            	if(stu[j].score2>stu[j-1].score2) {	//再次比较第二科
		                temp=stu[j-1];
		                stu[j-1]=stu[j];
		                stu[j]=temp;
	            	}
	            	else if(stu[j].score2==stu[j-1].score2) {
		            	if(stu[j].score3>stu[j-1].score3) {//最后比较第三科 
			                temp=stu[j-1];
			                stu[j-1]=stu[j];
			                stu[j]=temp;
		            	}
		            }
	            }
            }
        }
	}
	
	// 输出成绩排名 
	fprintf(fp,"科目一平均分:%.2lf 科目二平均分:%.2lf 科目三平均分:%.2lf\n",Score1/5,Score2/5,Score3/5); 
	for(i=0;i<5;i++)
		fprintf(fp,"%d %s %.2lf %.2lf %.2lf %.2lf\n",stu[i].ID,stu[i].name,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].score0);
	
//    ch=getchar();
//	while(ch!='#'){			//写文件操作                        
//		fputc(ch,fp);		//调用fputc将刚读的字符写到文件      
//		ch=getchar();
//	}
	// 关闭文件
	fclose(fp);
	
	// 从文件中读取数据 
	fp=fopen("E:\\Desktop\\file2.txt","r");
	if(!fp){			// 文件打开失败结束程序 
		printf("can not open file\n");
		exit(1);
	}
	//读文件操作
	while((ch=fgetc(fp))!=EOF) {                        
		putchar(ch);
	}
	fclose(fp);
	
	return 0;
}

// 测试数据 
//5 chl 21 45 65
//4 ch2 87 32 12
//3 ch3 54 67 34
//1 ch4 12 43 23
//2 ch5 98 78 96 

在这里插入图片描述


http://www.kler.cn/a/353387.html

相关文章:

  • 如何用 ESP32-CAM 做一个实时视频流服务器
  • 阿里云-Centos9-安装Docker-配置镜像拉取加速地址-开机自启
  • 回溯算法汇总
  • Java多线程
  • Unity3d 基于Barracuda推理库和YOLO算法实现对象检测功能
  • Qt:图片文字转base64程序
  • 云栖实录 | 智能运维年度重磅发布及大模型实践解读
  • Docker配置网站环境
  • Redis 消息队列:实现、操作与性能优化
  • 【SSM详细教程】-01-Spring容器以及配置详解
  • C#从零开始学习(Head First C#)
  • 【论文阅读笔记】The Chubby lock service for loosely-coupled distributed systems
  • Spring Boot环境下的大创项目协作工具
  • 2024ideaUI切换和svn与git的切换
  • Floyd
  • 文本语义检索系统的搭建过程,涵盖了召回、排序以及Milvus召回系统、短视频推荐等相关内容
  • C++ | Leetcode C++题解之第476题数字的补数
  • ThinkPHP 3.2 + Nginx 页面404问题
  • 可以在桌面上用的倒计时提醒app下载
  • 什么是NLP?
  • 完全指南:如何高效进行业务应用开发?
  • 解决VScode(Visual Studio Code)中的乱码问题. 2024-10-13
  • 汽车管理系统——级联下拉框
  • 在 Android Studio 中引入android.os.SystemProperties
  • 计算机网络自顶向下(3)---TCPsocket