用c语言写出对一个有N个学生的班级,每个学生有3门课程,分别为语文,数学,语言。该系统实现对班级成绩的录入、显示、修改、排序、保存等操作的管理。功能要求: (1)本系统采用一个结构体数组,每个数据的结构应当包括:学号、姓名、M门课程名称。 (2)本系统显示这样的菜单: 系统功能选项: a、 数据导入及显示 b、新记录输入 c、 删除记录 d、成绩查询 e、 成绩修改( 要求先输入密码) f、 成绩排序 (可按单科排序或按平均分排序) b、 成绩保存 c、 成绩统计 1)显示每门课程成绩最高的学生的基本信息 2)显示每门课程的平均成绩 3)显示超过某门课程平均成绩的学生人数 g、 退出系统 注意:需保证学号唯一性 (该题目用数组完成)

时间: 2024-01-12 19:05:12 浏览: 64
好的,我可以为你提供一个班级成绩管理系统的示例代码。代码主要实现了上述9个功能,具体实现细节可以参考代码注释。 ``` #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_STUDENTS 100 // 最多学生数量 #define MAX_NAME_LEN 20 // 最长姓名长度 #define MAX_PASSWORD_LEN 20 // 最长密码长度 // 学生信息结构体 struct student { int id; // 学号 char name[MAX_NAME_LEN]; // 姓名 int score[3]; // 3门课程的成绩 }; // 学生信息数组 struct student students[MAX_STUDENTS]; // 学生数量 int num_students = 0; // 密码 char password[MAX_PASSWORD_LEN] = "123456"; // 默认密码为123456 // 显示菜单 void show_menu() { printf("系统功能选项:\n"); printf("a、数据导入及显示\n"); printf("b、新记录输入\n"); printf("c、删除记录\n"); printf("d、成绩查询\n"); printf("e、成绩修改(要求先输入密码)\n"); printf("f、成绩排序(可按单科排序或按平均分排序)\n"); printf("g、成绩保存\n"); printf("h、成绩统计\n"); printf("i、退出系统\n"); } // 显示学生信息 void show_students() { int i, j; printf("学号\t姓名\t语文\t数学\t英语\n"); for (i = 0; i < num_students; i++) { printf("%d\t%s\t", students[i].id, students[i].name); for (j = 0; j < 3; j++) { printf("%d\t", students[i].score[j]); } printf("\n"); } } // 导入学生信息 void import_students() { FILE *fp; fp = fopen("students.txt", "r"); if (fp == NULL) { printf("无法打开文件\n"); return; } while (fscanf(fp, "%d %s %d %d %d", &students[num_students].id, students[num_students].name, &students[num_students].score[0], &students[num_students].score[1], &students[num_students].score[2]) == 5) { num_students++; } fclose(fp); } // 保存学生信息 void save_students() { FILE *fp; int i, j; fp = fopen("students.txt", "w"); if (fp == NULL) { printf("无法打开文件\n"); return; } for (i = 0; i < num_students; i++) { fprintf(fp, "%d %s", students[i].id, students[i].name); for (j = 0; j < 3; j++) { fprintf(fp, " %d", students[i].score[j]); } fprintf(fp, "\n"); } fclose(fp); } // 新记录输入 void add_student() { int id, i, j; char name[MAX_NAME_LEN]; printf("请输入学号:"); scanf("%d", &id); for (i = 0; i < num_students; i++) { if (students[i].id == id) { printf("该学号已存在\n"); return; } } printf("请输入姓名:"); scanf("%s", name); strcpy(students[num_students].name, name); students[num_students].id = id; for (j = 0; j < 3; j++) { printf("请输入%s成绩:", (j == 0 ? "语文" : (j == 1 ? "数学" : "英语"))); scanf("%d", &students[num_students].score[j]); } num_students++; } // 删除记录 void delete_student() { int id, i, j; printf("请输入要删除的学号:"); scanf("%d", &id); for (i = 0; i < num_students; i++) { if (students[i].id == id) { for (j = i; j < num_students - 1; j++) { students[j] = students[j + 1]; } num_students--; printf("删除成功\n"); return; } } printf("该学号不存在\n"); } // 成绩查询 void query_score() { int id, i, j; printf("请输入要查询成绩的学号:"); scanf("%d", &id); for (i = 0; i < num_students; i++) { if (students[i].id == id) { printf("学号\t姓名\t语文\t数学\t英语\n"); printf("%d\t%s\t", students[i].id, students[i].name); for (j = 0; j < 3; j++) { printf("%d\t", students[i].score[j]); } printf("\n"); return; } } printf("该学号不存在\n"); } // 成绩修改 void modify_score() { int id, i, j; char input_password[MAX_PASSWORD_LEN]; printf("请输入密码:"); scanf("%s", input_password); if (strcmp(input_password, password) != 0) { printf("密码错误\n"); return; } printf("请输入要修改成绩的学号:"); scanf("%d", &id); for (i = 0; i < num_students; i++) { if (students[i].id == id) { for (j = 0; j < 3; j++) { printf("请输入%s成绩:", (j == 0 ? "语文" : (j == 1 ? "数学" : "英语"))); scanf("%d", &students[i].score[j]); } printf("修改成功\n"); return; } } printf("该学号不存在\n"); } // 按照单科成绩排序 void sort_by_score(int subject) { int i, j, max_idx, temp; struct student max_student; for (i = 0; i < num_students - 1; i++) { max_idx = i; for (j = i + 1; j < num_students; j++) { if (students[j].score[subject] > students[max_idx].score[subject]) { max_idx = j; } } if (max_idx != i) { max_student = students[max_idx]; students[max_idx] = students[i]; students[i] = max_student; } } } // 按照平均分排序 void sort_by_avg_score() { int i, j, max_idx; float max_avg_score, avg_score; struct student max_student; for (i = 0; i < num_students - 1; i++) { max_idx = i; max_avg_score = (students[i].score[0] + students[i].score[1] + students[i].score[2]) / 3.0; for (j = i + 1; j < num_students; j++) { avg_score = (students[j].score[0] + students[j].score[1] + students[j].score[2]) / 3.0; if (avg_score > max_avg_score) { max_idx = j; max_avg_score = avg_score; } } if (max_idx != i) { max_student = students[max_idx]; students[max_idx] = students[i]; students[i] = max_student; } } } // 成绩排序 void sort_score() { int choice; printf("请选择排序方式(1-按语文成绩,2-按数学成绩,3-按英语成绩,4-按平均分):"); scanf("%d", &choice); switch (choice) { case 1: sort_by_score(0); break; case 2: sort_by_score(1); break; case 3: sort_by_score(2); break; case 4: sort_by_avg_score(); break; default: printf("无效的选择\n"); break; } } // 统计成绩 void statistics() { int i, j; float avg_score; int count; printf("每门课程成绩最高的学生的基本信息:\n"); printf("科目\t学号\t姓名\t成绩\n"); for (j = 0; j < 3; j++) { int max_score = -1; int max_idx = -1; for (i = 0; i < num_students; i++) { if (students[i].score[j] > max_score) { max_score = students[i].score[j]; max_idx = i; } } printf("%s\t%d\t%s\t%d\n", (j == 0 ? "语文" : (j == 1 ? "数学" : "英语")), students[max_idx].id, students[max_idx].name, max_score); } printf("每门课程的平均成绩:\n"); printf("科目\t平均成绩\n"); for (j = 0; j < 3; j++) { avg_score = 0; for (i = 0; i < num_students; i++) { avg_score += students[i].score[j]; } avg_score /= num_students; printf("%s\t%.2f\n", (j == 0 ? "语文" : (j == 1 ? "数学" : "英语")), avg_score); } printf("超过某门课程平均成绩的学生人数:\n"); for (j = 0; j < 3; j++) { avg_score = 0; for (i = 0; i < num_students; i++) { avg_score += students[i].score[j]; } avg_score /= num_students; count = 0; for (i = 0; i < num_students; i++) { if (students[i].score[j] > avg_score) { count++; } } printf("%s\t%d\n", (j == 0 ? "语文" : (j == 1 ? "数学" : "英语")), count); } } int main() { int choice; import_students(); // 导入学生信息 while (1) { show_menu(); // 显示菜单 printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: show_students(); // 显示学生信息 break; case 2: add_student(); // 新记录输入 break; case 3: delete_student(); // 删除记录 break; case 4: query_score(); // 成绩查询 break; case 5: modify_score(); // 成绩修改 break; case 6: sort_score(); // 成绩排序 break; case 7: save_students(); // 成绩保存 break; case 8: statistics(); // 成绩统计 break; case 9: printf("退出系统\n"); return 0; default: printf("无效的选择\n"); break; } } return 0; } ``` 注意事项: - 该代码中使用了文件操作,需要确保当前目录下有名为`students.txt`的文件,并且文件格式为:每行一个学生的信息,格式为`学号 姓名 语文成绩 数学成绩 英语成绩`。例如:`1 张三 80 90 70`。 - 该代码中默认密码为`123456`,可以在代码中修改。
阅读全文

相关推荐

最新推荐

recommend-type

小学生测验C语言课程设计报告

此设计旨在提升学生对C语言的理解和应用能力,培养良好的编程习惯,同时为后续计算机课程学习奠定基础。设计的核心目标是构建一个能够自动化处理试题库、试题录入、随机抽题、答题与自动判卷的在线测验系统。 首先...
recommend-type

C语言实现学生选修课程系统设计

本系统主要使用C语言实现学生选修课程系统的设计,旨在提供一个功能完善的学生选修课程管理系统。该系统具有添加、查询、显示、编辑、删除和统计等多种功能,能够满足学生和课程信息的管理需求。 添加功能 添加...
recommend-type

在C语言中输入一个大写字母,将其转变成一个小写字母,并且有相应的提示。

C语言中的字符常量是用单引号 `'` 包围的,而变量则是用 `%c` 格式符在 `scanf()` 或 `printf()` 函数中处理。在ASCII码表中,大写字母和小写字母之间存在固定的偏移量,对于英文来说,这个偏移量通常是32。标题提到...
recommend-type

C语言实现简单学生选课管理系统

本文详细介绍了C语言实现简单学生选课管理系统的设计和实现过程,涵盖了结构体、链表、文件读写操作、密码检测函数、输入限制函数、通用函数和系统设计等多个知识点,为读者提供了一个完整的C语言实现学生选课管理...
recommend-type

C语言实现输入一个字符串后打印出该字符串中字符的所有排列

首先,全排列的基本思想是:对于一个包含n个不同元素的序列,我们可以先固定第一个位置,然后对剩下的n-1个元素进行全排列,然后再将第一个位置的元素替换为剩余元素中的每一个,依次类推,直到所有元素都在所有位置...
recommend-type

平尾装配工作平台运输支撑系统设计与应用

资源摘要信息:"该压缩包文件名为‘行业分类-设备装置-用于平尾装配工作平台的运输支撑系统.zip’,虽然没有提供具体的标签信息,但通过文件标题可以推断出其内容涉及的是航空或者相关重工业领域内的设备装置。从标题来看,该文件集中讲述的是有关平尾装配工作平台的运输支撑系统,这是一种专门用于支撑和运输飞机平尾装配的特殊设备。 平尾,即水平尾翼,是飞机尾部的一个关键部件,它对于飞机的稳定性和控制性起到至关重要的作用。平尾的装配工作通常需要在一个特定的平台上进行,这个平台不仅要保证装配过程中平尾的稳定,还需要适应平尾的搬运和运输。因此,设计出一个合适的运输支撑系统对于提高装配效率和保障装配质量至关重要。 从‘用于平尾装配工作平台的运输支撑系统.pdf’这一文件名称可以推断,该PDF文档应该是详细介绍这种支撑系统的构造、工作原理、使用方法以及其在平尾装配工作中的应用。文档可能包括以下内容: 1. 支撑系统的设计理念:介绍支撑系统设计的基本出发点,如便于操作、稳定性高、强度大、适应性强等。可能涉及的工程学原理、材料学选择和整体结构布局等内容。 2. 结构组件介绍:详细介绍支撑系统的各个组成部分,包括支撑框架、稳定装置、传动机构、导向装置、固定装置等。对于每一个部件的功能、材料构成、制造工艺、耐腐蚀性以及与其他部件的连接方式等都会有详细的描述。 3. 工作原理和操作流程:解释运输支撑系统是如何在装配过程中起到支撑作用的,包括如何调整支撑点以适应不同重量和尺寸的平尾,以及如何进行运输和对接。操作流程部分可能会包含操作步骤、安全措施、维护保养等。 4. 应用案例分析:可能包含实际操作中遇到的问题和解决方案,或是对不同机型平尾装配过程的支撑系统应用案例的详细描述,以此展示系统的实用性和适应性。 5. 技术参数和性能指标:列出支撑系统的具体技术参数,如载重能力、尺寸规格、工作范围、可调节范围、耐用性和可靠性指标等,以供参考和评估。 6. 安全和维护指南:对于支撑系统的使用安全提供指导,包括操作安全、应急处理、日常维护、定期检查和故障排除等内容。 该支撑系统作为专门针对平尾装配而设计的设备,对于飞机制造企业来说,掌握其详细信息是提高生产效率和保障产品质量的重要一环。同时,这种支撑系统的设计和应用也体现了现代工业在专用设备制造方面追求高效、安全和精确的趋势。"
recommend-type

管理建模和仿真的文件

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

MATLAB遗传算法探索:寻找随机性与确定性的平衡艺术

![MATLAB多种群遗传算法优化](https://img-blog.csdnimg.cn/39452a76c45b4193b4d88d1be16b01f1.png) # 1. 遗传算法的基本概念与起源 遗传算法(Genetic Algorithm, GA)是一种模拟自然选择和遗传学机制的搜索优化算法。起源于20世纪60年代末至70年代初,由John Holland及其学生和同事们在研究自适应系统时首次提出,其理论基础受到生物进化论的启发。遗传算法通过编码一个潜在解决方案的“基因”,构造初始种群,并通过选择、交叉(杂交)和变异等操作模拟生物进化过程,以迭代的方式不断优化和筛选出最适应环境的
recommend-type

如何在S7-200 SMART PLC中使用MB_Client指令实现Modbus TCP通信?请详细解释从连接建立到数据交换的完整步骤。

为了有效地掌握S7-200 SMART PLC中的MB_Client指令,以便实现Modbus TCP通信,建议参考《S7-200 SMART Modbus TCP教程:MB_Client指令与功能码详解》。本教程将引导您了解从连接建立到数据交换的整个过程,并详细解释每个步骤中的关键点。 参考资源链接:[S7-200 SMART Modbus TCP教程:MB_Client指令与功能码详解](https://wenku.csdn.net/doc/119yes2jcm?spm=1055.2569.3001.10343) 首先,确保您的S7-200 SMART CPU支持开放式用户通
recommend-type

MAX-MIN Ant System:用MATLAB解决旅行商问题

资源摘要信息:"Solve TSP by MMAS: Using MAX-MIN Ant System to solve Traveling Salesman Problem - matlab开发" 本资源为解决经典的旅行商问题(Traveling Salesman Problem, TSP)提供了一种基于蚁群算法(Ant Colony Optimization, ACO)的MAX-MIN蚁群系统(MAX-MIN Ant System, MMAS)的Matlab实现。旅行商问题是一个典型的优化问题,要求找到一条最短的路径,让旅行商访问每一个城市一次并返回起点。这个问题属于NP-hard问题,随着城市数量的增加,寻找最优解的难度急剧增加。 MAX-MIN Ant System是一种改进的蚁群优化算法,它在基本的蚁群算法的基础上,对信息素的更新规则进行了改进,以期避免过早收敛和局部最优的问题。MMAS算法通过限制信息素的上下界来确保算法的探索能力和避免过早收敛,它在某些情况下比经典的蚁群系统(Ant System, AS)和带有局部搜索的蚁群系统(Ant Colony System, ACS)更为有效。 在本Matlab实现中,用户可以通过调用ACO函数并传入一个TSP问题文件(例如"filename.tsp")来运行MMAS算法。该问题文件可以是任意的对称或非对称TSP实例,用户可以从特定的网站下载多种标准TSP问题实例,以供测试和研究使用。 使用此资源的用户需要注意,虽然该Matlab代码可以免费用于个人学习和研究目的,但若要用于商业用途,则需要联系作者获取相应的许可。作者的电子邮件地址为***。 此外,压缩包文件名为"MAX-MIN%20Ant%20System.zip",该压缩包包含Matlab代码文件和可能的示例数据文件。用户在使用之前需要将压缩包解压,并将文件放置在Matlab的适当工作目录中。 为了更好地理解和应用该资源,用户应当对蚁群优化算法有初步了解,尤其是对MAX-MIN蚁群系统的基本原理和运行机制有所掌握。此外,熟悉Matlab编程环境和拥有一定的编程经验将有助于用户根据个人需求修改和扩展算法。 在实际应用中,用户可以根据问题规模调整MMAS算法的参数,如蚂蚁数量、信息素蒸发率、信息素增量等,以获得最优的求解效果。此外,也可以结合其他启发式或元启发式算法,如遗传算法、模拟退火等,来进一步提高算法的性能。 总之,本资源为TSP问题的求解提供了一种有效的算法框架,且Matlab作为编程工具的易用性和强大的计算能力,使得该资源成为算法研究人员和工程技术人员的有力工具。通过本资源的应用,用户将能够深入探索并实现蚁群优化算法在实际问题中的应用,为解决复杂的优化问题提供一种新的思路和方法。