学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail,C语言、数学和英语成绩等。试设计一个学生信息管理系统,使之能提供以下功能:  系统以菜单方式工作  学生信息录入功能---输入  学生信息浏览功能——输出  查询、排序功能——算法 1、按学号查询 2、按姓名查询 3、按C语言、数学和英语成绩分别排序  学生信息的插入、删除与修改

时间: 2023-12-22 14:19:07 浏览: 57
好的,以下是一个简单的学生信息管理系统的设计,供你参考: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_STUDENT_NUM 100 struct student { int id; char name[20]; int age; char sex[5]; char birthdate[20]; char address[100]; char phone[20]; char email[50]; int c_score; int math_score; int english_score; }; struct student students[MAX_STUDENT_NUM]; int current_student_num = 0; void print_menu(); void add_student(); void view_all_students(); void search_by_id(); void search_by_name(); void sort_by_c_score(); void sort_by_math_score(); void sort_by_english_score(); void update_student(); void delete_student(); int main() { int choice; while (1) { print_menu(); printf("请输入你要选择的操作:"); scanf("%d", &choice); switch (choice) { case 1: add_student(); break; case 2: view_all_students(); break; case 3: search_by_id(); break; case 4: search_by_name(); break; case 5: sort_by_c_score(); break; case 6: sort_by_math_score(); break; case 7: sort_by_english_score(); break; case 8: update_student(); break; case 9: delete_student(); break; case 0: exit(0); break; default: printf("输入无效,请重新输入。\n"); break; } printf("\n"); } return 0; } void print_menu() { printf("**********学生信息管理系统**********\n"); printf("* 1. 录入学生信息 *\n"); printf("* 2. 查看所有学生信息 *\n"); printf("* 3. 按学号查询学生信息 *\n"); printf("* 4. 按姓名查询学生信息 *\n"); printf("* 5. 按C语言成绩排序学生信息 *\n"); printf("* 6. 按数学成绩排序学生信息 *\n"); printf("* 7. 按英语成绩排序学生信息 *\n"); printf("* 8. 修改学生信息 *\n"); printf("* 9. 删除学生信息 *\n"); printf("* 0. 退出程序 *\n"); printf("*************************************\n"); } void add_student() { struct student s; printf("请输入学生信息:\n"); printf("学号:"); scanf("%d", &s.id); printf("姓名:"); scanf("%s", s.name); printf("年龄:"); scanf("%d", &s.age); printf("性别:"); scanf("%s", s.sex); printf("出生年月:"); scanf("%s", s.birthdate); printf("地址:"); scanf("%s", s.address); printf("电话:"); scanf("%s", s.phone); printf("E-mail:"); scanf("%s", s.email); printf("C语言成绩:"); scanf("%d", &s.c_score); printf("数学成绩:"); scanf("%d", &s.math_score); printf("英语成绩:"); scanf("%d", &s.english_score); students[current_student_num++] = s; printf("学生信息录入成功!\n"); } void view_all_students() { if (current_student_num == 0) { printf("没有学生信息。\n"); return; } printf("学号\t姓名\t年龄\t性别\t出生年月\t地址\t\t电话\t\tE-mail\t\tC语言\t数学\t英语\n"); for (int i = 0; i < current_student_num; i++) { printf("%d\t%s\t%d\t%s\t%s\t%s\t%s\t%s\t%d\t%d\t%d\n", students[i].id, students[i].name, students[i].age, students[i].sex, students[i].birthdate, students[i].address, students[i].phone, students[i].email, students[i].c_score, students[i].math_score, students[i].english_score); } } void search_by_id() { int id; int found = 0; printf("请输入要查询的学号:"); scanf("%d", &id); for (int i = 0; i < current_student_num; i++) { if (students[i].id == id) { printf("学号\t姓名\t年龄\t性别\t出生年月\t地址\t\t电话\t\tE-mail\t\tC语言\t数学\t英语\n"); printf("%d\t%s\t%d\t%s\t%s\t%s\t%s\t%s\t%d\t%d\t%d\n", students[i].id, students[i].name, students[i].age, students[i].sex, students[i].birthdate, students[i].address, students[i].phone, students[i].email, students[i].c_score, students[i].math_score, students[i].english_score); found = 1; break; } } if (!found) { printf("未找到该学生信息。\n"); } } void search_by_name() { char name[20]; int found = 0; printf("请输入要查询的姓名:"); scanf("%s", name); for (int i = 0; i < current_student_num; i++) { if (strcmp(students[i].name, name) == 0) { printf("学号\t姓名\t年龄\t性别\t出生年月\t地址\t\t电话\t\tE-mail\t\tC语言\t数学\t英语\n"); printf("%d\t%s\t%d\t%s\t%s\t%s\t%s\t%s\t%d\t%d\t%d\n", students[i].id, students[i].name, students[i].age, students[i].sex, students[i].birthdate, students[i].address, students[i].phone, students[i].email, students[i].c_score, students[i].math_score, students[i].english_score); found = 1; } } if (!found) { printf("未找到该学生信息。\n"); } } void sort_by_c_score() { for (int i = 0; i < current_student_num - 1; i++) { for (int j = 0; j < current_student_num - i - 1; j++) { if (students[j].c_score < students[j+1].c_score) { struct student tmp = students[j]; students[j] = students[j+1]; students[j+1] = tmp; } } } view_all_students(); } void sort_by_math_score() { for (int i = 0; i < current_student_num - 1; i++) { for (int j = 0; j < current_student_num - i - 1; j++) { if (students[j].math_score < students[j+1].math_score) { struct student tmp = students[j]; students[j] = students[j+1]; students[j+1] = tmp; } } } view_all_students(); } void sort_by_english_score() { for (int i = 0; i < current_student_num - 1; i++) { for (int j = 0; j < current_student_num - i - 1; j++) { if (students[j].english_score < students[j+1].english_score) { struct student tmp = students[j]; students[j] = students[j+1]; students[j+1] = tmp; } } } view_all_students(); } void update_student() { int id; int found = 0; printf("请输入要修改的学生的学号:"); scanf("%d", &id); for (int i = 0; i < current_student_num; i++) { if (students[i].id == id) { found = 1; printf("请输入修改后的学生信息:\n"); printf("学号:"); scanf("%d", &students[i].id); printf("姓名:"); scanf("%s", students[i].name); printf("年龄:"); scanf("%d", &students[i].age); printf("性别:"); scanf("%s", students[i].sex); printf("出生年月:"); scanf("%s", students[i].birthdate); printf("地址:"); scanf("%s", students[i].address); printf("电话:"); scanf("%s", students[i].phone); printf("E-mail:"); scanf("%s", students[i].email); printf("C语言成绩:"); scanf("%d", &students[i].c_score); printf("数学成绩:"); scanf("%d", &students[i].math_score); printf("英语成绩:"); scanf("%d", &students[i].english_score); printf("学生信息修改成功!\n"); break; } } if (!found) { printf("未找到该学生信息。\n"); } } void delete_student() { int id; int found = 0; printf("请输入要删除的学生的学号:"); scanf("%d", &id); for (int i = 0; i < current_student_num; i++) { if (students[i].id == id) { found = 1; for (int j = i; j < current_student_num - 1; j++) { students[j] = students[j+1]; } current_student_num--; printf("学生信息删除成功!\n"); break; } } if (!found) { printf("未找到该学生信息。\n"); } } ``` 上面代码中,定义了一个 `struct student` 结构体,表示学生信息。然后定义了一个 `students` 数组用于存储所有学生信息,以及一个 `current_student_num` 变量记录当前学生数量。 菜单功能通过 `print_menu()` 函数实现,各功能通过不同的函数实现。其中,学生信息录入功能通过 `add_student()` 函数实现,学生信息浏览功能通过 `view_all_students()` 函数实现,查询功能通过 `search_by_id()` 和 `search_by_name()` 函数实现,排序功能通过 `sort_by_c_score()`、`sort_by_math_score()` 和 `sort_by_english_score()` 函数实现,学生信息的插入、删除与修改通过 `update_student()` 和 `delete_student()` 函数实现。 以上是一个简单的学生信息管理系统的设计,具体实现可以根据需求进行修改和完善。

相关推荐

最新推荐

recommend-type

学生信息管理学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail等。设计“学生信息管理系统”

学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail等。设计“学生信息管理系统”,使之能提供以下功能: 1)系统以菜单方式工作; 2)学生信息录入功能; 3)学生信息浏览功能; 4)查询、...
recommend-type

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

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

行政数据分析看板8.xlsx

Excel数据看板,Excel办公模板,Excel模板下载,Excel数据统计,数据展示
recommend-type

自动驾驶运动规划(Motion Planning).pdf

自动驾驶运动规划(Motion Planning)问题分析
recommend-type

跟我一起写makefile

跟我一起写makefile的PDF,学习用。
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

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

:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向

![:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向](https://img-blog.csdnimg.cn/7e3d12895feb4651b9748135c91e0f1a.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5rKJ6YaJ77yM5LqO6aOO5Lit,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. YOLO目标检测算法简介 YOLO(You Only Look Once)是一种
recommend-type

def ObjFun(x,y,beta): # 目标函数 """ Logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: loss value """ n = x.shape[0] p = x.shape[1] pred = 1 / (1 + np.exp(-np.dot(x, beta))) pred = np.clip(pred, 1e-15, 1 - 1e-15) # 将预测值限制在一个很小的区间内 ObjVal = -np.sum(y * np.log(pred) + (1 - y) * np.log(1 - pred)) / n return ObjVal

好的,根据上面的目标函数,我们可以推导出其对应的梯度向量函数,如下所示: def gradient(x, y, beta): """ Compute gradient of the logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: gradient vector """ n = x.shape[0] pred = 1 /
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。