帮我用c语言写一个学生管理系统

时间: 2023-11-14 11:07:00 浏览: 35
好的,我可以给你一个简单的学生管理系统的示例代码,你可以基于此进行修改和扩展。以下是代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_STUDENTS 100 // 最大学生数量 #define MAX_NAME_LENGTH 50 // 最大姓名长度 // 学生结构体 typedef struct { int id; // 学生编号 char name[MAX_NAME_LENGTH]; // 学生姓名 int age; // 学生年龄 float score; // 学生成绩 } Student; // 全局变量 Student students[MAX_STUDENTS]; // 学生数组 int num_students = 0; // 学生数量 // 函数声明 void add_student(); void delete_student(); void modify_student(); void query_student(); void show_menu(); void save_data(); void load_data(); // 主函数 int main() { load_data(); // 加载数据 while (1) { show_menu(); // 显示菜单 int choice; scanf("%d", &choice); switch (choice) { case 1: add_student(); // 添加学生 break; case 2: delete_student(); // 删除学生 break; case 3: modify_student(); // 修改学生信息 break; case 4: query_student(); // 查询学生信息 break; case 5: save_data(); // 保存数据 exit(0); // 退出程序 default: printf("输入有误,请重新输入!\n"); break; } } return 0; } // 添加学生 void add_student() { printf("请输入学生姓名:\n"); char name[MAX_NAME_LENGTH]; scanf("%s", name); printf("请输入学生年龄:\n"); int age; scanf("%d", &age); printf("请输入学生成绩:\n"); float score; scanf("%f", &score); // 生成学生编号 int id = num_students + 1; // 创建学生对象 Student student = {id, name, age, score}; // 添加学生到数组 students[num_students++] = student; printf("添加成功!\n"); } // 删除学生 void delete_student() { printf("请输入要删除的学生编号:\n"); int id; scanf("%d", &id); int index = -1; for (int i = 0; i < num_students; i++) { if (students[i].id == id) { index = i; break; } } if (index == -1) { printf("未找到该学生!\n"); } else { for (int i = index; i < num_students - 1; i++) { students[i] = students[i + 1]; } num_students--; printf("删除成功!\n"); } } // 修改学生信息 void modify_student() { printf("请输入要修改的学生编号:\n"); int id; scanf("%d", &id); int index = -1; for (int i = 0; i < num_students; i++) { if (students[i].id == id) { index = i; break; } } if (index == -1) { printf("未找到该学生!\n"); } else { Student *student = &students[index]; printf("请输入学生姓名(原值:%s):\n", student->name); char name[MAX_NAME_LENGTH]; scanf("%s", name); strcpy(student->name, name); printf("请输入学生年龄(原值:%d):\n", student->age); int age; scanf("%d", &age); student->age = age; printf("请输入学生成绩(原值:%f):\n", student->score); float score; scanf("%f", &score); student->score = score; printf("修改成功!\n"); } } // 查询学生信息 void query_student() { printf("请输入要查询的学生编号:\n"); int id; scanf("%d", &id); int index = -1; for (int i = 0; i < num_students; i++) { if (students[i].id == id) { index = i; break; } } if (index == -1) { printf("未找到该学生!\n"); } else { Student student = students[index]; printf("学生编号:%d\n", student.id); printf("学生姓名:%s\n", student.name); printf("学生年龄:%d\n", student.age); printf("学生成绩:%f\n", student.score); } } // 显示菜单 void show_menu() { printf("欢迎使用学生管理系统!\n"); printf("1. 添加学生\n"); printf("2. 删除学生\n"); printf("3. 修改学生信息\n"); printf("4. 查询学生信息\n"); printf("5. 退出程序\n"); printf("请选择操作:\n"); } // 保存数据 void save_data() { FILE *fp = fopen("data.txt", "w"); if (fp == NULL) { printf("文件打开失败!\n"); return; } for (int i = 0; i < num_students; i++) { Student student = students[i]; fprintf(fp, "%d %s %d %f\n", student.id, student.name, student.age, student.score); } fclose(fp); } // 加载数据 void load_data() { FILE *fp = fopen("data.txt", "r"); if (fp == NULL) { printf("文件打开失败!\n"); return; } while (1) { int id; char name[MAX_NAME_LENGTH]; int age; float score; int result = fscanf(fp, "%d %s %d %f\n", &id, name, &age, &score); if (result == EOF) { break; } Student student = {id, name, age, score}; students[num_students++] = student; } fclose(fp); } ``` 这个简单的学生管理系统包含了添加学生、删除学生、修改学生信息、查询学生信息和保存数据等功能,可以满足基本的学生管理需求。当然,你可以根据自己的需求进行修改和扩展。

相关推荐

最新推荐

recommend-type

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

主要为大家详细介绍了C语言实现简单学生学籍管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

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

主要为大家详细介绍了C语言实现简单学生选课管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言数组实现学生信息管理系统设计

主要为大家详细介绍了C语言数组实现学生信息管理系统设计,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

###对华为OD分布式操作系统的详细介绍

华为OD
recommend-type

2110220116吴骏博.py

2110220116吴骏博.py
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的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。