将文件 stu_info2.txt 中学生信息读出,按照平均分排序处理,再重新写入文件 “stu_sort.txt”并保存于磁盘上。用C语言完成。

时间: 2024-03-04 14:50:17 浏览: 17
好的,这是一个文件读写和排序的问题,我将为您提供代码参考: ```c #include <stdio.h> #include <string.h> #include <stdlib.h> #define MAX_LINE_LEN 100 // 文件中每行最大长度 #define MAX_STU_NUM 100 // 最大学生人数 struct student { char name[20]; // 姓名 int id; // 学号 int score[3]; // 3门课程成绩 double avg_score; // 平均成绩 }; int compare(const void *a, const void *b) { struct student *s1 = (struct student *)a; struct student *s2 = (struct student *)b; return s1->avg_score > s2->avg_score ? -1 : 1; } int main() { FILE *fp; char line[MAX_LINE_LEN]; struct student stu_list[MAX_STU_NUM]; int count = 0; // 读文件 fp = fopen("stu_info2.txt", "r"); if (fp == NULL) { printf("Cannot open file stu_info2.txt\n"); return 1; } while (fgets(line, MAX_LINE_LEN, fp)) { sscanf(line, "%s %d %d %d %d", stu_list[count].name, &stu_list[count].id, &stu_list[count].score[0], &stu_list[count].score[1], &stu_list[count].score[2]); stu_list[count].avg_score = (stu_list[count].score[0] + stu_list[count].score[1] + stu_list[count].score[2]) / 3.0; count++; } fclose(fp); // 排序 qsort(stu_list, count, sizeof(struct student), compare); // 写文件 fp = fopen("stu_sort.txt", "w"); if (fp == NULL) { printf("Cannot open file stu_sort.txt\n"); return 1; } for (int i = 0; i < count; i++) { fprintf(fp, "%s %d %d %d %lf\n", stu_list[i].name, stu_list[i].id, stu_list[i].score[0], stu_list[i].score[1], stu_list[i].score[2], stu_list[i].avg_score); } fclose(fp); printf("Sort finished.\n"); return 0; } ``` 代码中定义了一个结构体 `student`,用于存储每个学生的信息,包括姓名、学号、三门课程成绩、平均成绩。首先读取文件,将每个学生的信息存储在结构体数组 `stu_list` 中,并计算平均成绩。然后使用 `qsort` 函数对学生信息进行排序,排序的依据是平均成绩。最后将排序结果写入文件,每行包括姓名、学号、三门课程成绩和平均成绩。 注意,这里的排序是按照平均分从高到低排序,因此 `compare` 函数返回的结果是 `s1->avg_score > s2->avg_score ? -1 : 1`,如果需要按照平均分从低到高排序,可以将返回值反过来。 另外,代码中没有对输入文件中的错误情况进行处理,如果文件格式错误或者内容不符合要求,程序可能会出现异常。在实际使用中需要进行适当的错误处理。

相关推荐

最新推荐

recommend-type

六首页数字藏品NFT交易网React NextJS网站模板 六首页数字藏品nft交易网反应NextJS网站模板

六首页数字藏品NFT交易网React NextJS网站模板 六首页数字藏品nft交易网反应NextJS网站模板
recommend-type

wireshark安装教程入门

wireshark安装教程入门
recommend-type

基于C++负数据库的隐私保护在线医疗诊断系统

【作品名称】:基于C++负数据库的隐私保护在线医疗诊断系统 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】: 基于负数据库的隐私保护在线医疗诊断系统 NDBMedicalSystem 客户端及服务器端 本项目是在保护用户隐私的前提下,完成了对新冠肺炎、乳腺癌、眼疾等多种疾病的智能诊断。
recommend-type

基本的嵌入式操作系统给

任务管理
recommend-type

3-10.py

3-10
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。