编写一个菜单驱动的学生成绩管理程序,要求如下: 1)能输入并显示n个学生m门考试科目的成绩、总分和平均分。 2)按总分由高到低排序。 3)任意输入一个学号,能显示该学生的姓名、各门功课的成绩。 4)备份学生成绩的数据文件。 5)在用户输入数据有错误(如数据类型)或无效时,不会中断程序的执行,程序具有一定健壮性。

时间: 2023-06-19 07:03:31 浏览: 65
下面是一个简单的学生成绩管理程序,实现了上述要求: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_STUDENT 100 #define MAX_SUBJECT 10 #define FILENAME "data.txt" struct student { char name[20]; int id; int score[MAX_SUBJECT]; int total; float avg; }; struct student students[MAX_STUDENT]; int n = 0; // 学生数目 // 显示菜单 void display_menu() { printf("1. 输入学生成绩\n"); printf("2. 按总分排序\n"); printf("3. 按学号查找\n"); printf("4. 备份数据\n"); printf("5. 退出程序\n"); } // 输入学生成绩 void input_scores() { printf("请输入学生数目:"); scanf("%d", &n); for (int i = 0; i < n; i++) { struct student *s = &students[i]; printf("请输入第%d个学生的姓名和学号:", i+1); scanf("%s %d", s->name, &s->id); printf("请输入第%d个学生的成绩:", i+1); s->total = 0; for (int j = 0; j < MAX_SUBJECT; j++) { scanf("%d", &s->score[j]); s->total += s->score[j]; } s->avg = (float)s->total / MAX_SUBJECT; } printf("输入完成!\n"); } // 按总分排序 void sort_by_total() { for (int i = 0; i < n-1; i++) { for (int j = i+1; j < n; j++) { if (students[i].total < students[j].total) { struct student tmp = students[i]; students[i] = students[j]; students[j] = tmp; } } } printf("排序完成!\n"); } // 按学号查找 void find_by_id() { int id, found = 0; printf("请输入学号:"); scanf("%d", &id); for (int i = 0; i < n; i++) { struct student *s = &students[i]; if (s->id == id) { printf("姓名:%s\n", s->name); printf("学号:%d\n", s->id); printf("成绩:"); for (int j = 0; j < MAX_SUBJECT; j++) { printf("%d ", s->score[j]); } printf("\n"); found = 1; break; } } if (!found) { printf("未找到该学生!\n"); } } // 备份数据 void backup_data() { FILE *fp; if ((fp = fopen(FILENAME, "w")) == NULL) { printf("无法打开文件!\n"); return; } for (int i = 0; i < n; i++) { struct student *s = &students[i]; fprintf(fp, "%s %d ", s->name, s->id); for (int j = 0; j < MAX_SUBJECT; j++) { fprintf(fp, "%d ", s->score[j]); } fprintf(fp, "\n"); } fclose(fp); printf("备份完成!\n"); } int main() { int choice; while (1) { display_menu(); printf("请输入选项:"); scanf("%d", &choice); switch (choice) { case 1: input_scores(); break; case 2: sort_by_total(); break; case 3: find_by_id(); break; case 4: backup_data(); break; case 5: printf("程序已退出!\n"); exit(0); default: printf("无效选项,请重新输入!\n"); } } return 0; } ``` 这个程序使用了结构体来表示学生,其中包含了姓名、学号、各门课程的成绩、总分和平均分等信息。使用一个全局数组来保存所有学生的信息。输入成绩时,从标准输入中读取学生的姓名、学号和各门课程的成绩,计算总分和平均分并保存到结构体中。排序时,使用冒泡排序算法按总分从高到低排序。查找时,从标准输入中读取学号并在学生数组中查找对应的学生信息。备份数据时,将所有学生的信息写入到文件中。程序通过一个无限循环来不断显示菜单并读取用户的选项。如果用户输入了无效的选项,程序会提示用户重新输入。

相关推荐

最新推荐

recommend-type

C语言程序设计实现学生成绩记录簿

通过编写c语言《学生成绩记录簿系统》让我知道所学的编程语言是需要多练多编写代码锻炼出来的。 1)C语言课程设计的主要目的是培养学生综合运用C语言程序设计课程所学到的知识,编写C程序解决实际问题的能力,以及...
recommend-type

c语言作业——学生成绩统计.docx

整个程序功能 (1)学生基本信息(学号、姓名、…….)录入; (2)学生成绩录入; (3)统计学生成绩分布情况(每个分数段人数); (4)查找最高分、最低分;计算学生成绩均值和方差;并输出这四个结果; (5)...
recommend-type

java实现学生成绩录入系统

主要为大家详细介绍了java实现学生成绩录入系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

c编写、单链表,对多个班级学生成绩进行管理

***通过终端输入实现****用C语言编写程序,以单链表为存储结构,对多个班级(以两个班为例)的学生成绩进行管理,要求实现如下功能: (1)通过终端或文件输入若干学生的班级号、学号、成绩,将每个班的数据分别保存...
recommend-type

scrapy练习 获取喜欢的书籍

主要是根据网上大神做的 项目一 https://zhuanlan.zhihu.com/p/687522335
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

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

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