编写一个学生成绩管理系统的菜单,分类本科生和研究生,都能实现学生的数据输入,修改,删除,查询,计算学生成绩。
时间: 2024-05-31 10:10:10 浏览: 54
好的,下面是一个简单的学生成绩管理系统的菜单:
**************************
学生成绩管理系统菜单
**************************
1. 本科生管理
2. 研究生管理
3. 退出
请选择菜单编号:
如果选择1,则进入本科生管理子菜单:
**************************
本科生管理子菜单
**************************
1. 添加本科生
2. 修改本科生信息
3. 删除本科生信息
4. 查询本科生信息
5. 计算本科生成绩
6. 返回上级菜单
请选择菜单编号:
如果选择2,则进入研究生管理子菜单:
**************************
研究生管理子菜单
**************************
1. 添加研究生
2. 修改研究生信息
3. 删除研究生信息
4. 查询研究生信息
5. 计算研究生成绩
6. 返回上级菜单
请选择菜单编号:
如果选择3,则退出程序。
相关问题
用c语言编写一个学生成绩管理系统的菜单,分类本科生和研究生,都能实现学生的数据输入,修改,删除,查询,计算学生成绩,成绩排名,统计等级人数,保存数据。,。
好的,以下是一个简单的学生成绩管理系统的菜单:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STUDENTS 100 // 最大学生数
// 学生结构体
typedef struct {
char name[20]; // 姓名
int id; // 学号
float grade; // 成绩
} Student;
// 学生数组
Student students[MAX_STUDENTS];
int num_students = 0; // 当前学生数
// 函数声明
void add_student();
void modify_student();
void delete_student();
void search_student();
void calculate_grade();
void rank_students();
void count_grades();
void save_data();
void load_data();
void show_menu();
int main() {
// 加载数据
load_data();
// 显示菜单
show_menu();
// 保存数据
save_data();
return 0;
}
// 添加学生
void add_student() {
if (num_students >= MAX_STUDENTS) {
printf("学生数已达到上限,无法添加新学生。\n");
return;
}
printf("请输入学生姓名:");
scanf("%s", students[num_students].name);
printf("请输入学生学号:");
scanf("%d", &students[num_students].id);
printf("请输入学生成绩:");
scanf("%f", &students[num_students].grade);
printf("添加成功!\n");
num_students++;
}
// 修改学生
void modify_student() {
int id;
int found = 0;
printf("请输入要修改的学生学号:");
scanf("%d", &id);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id) {
printf("请输入修改后的学生姓名(原姓名:%s):", students[i].name);
scanf("%s", students[i].name);
printf("请输入修改后的学生成绩(原成绩:%f):", students[i].grade);
scanf("%f", &students[i].grade);
printf("修改成功!\n");
found = 1;
break;
}
}
if (!found) {
printf("未找到该学生!\n");
}
}
// 删除学生
void delete_student() {
int id;
int found = 0;
printf("请输入要删除的学生学号:");
scanf("%d", &id);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id) {
for (int j = i; j < num_students - 1; j++) { // 从该学生开始,将后面的学生向前移动
students[j] = students[j + 1];
}
num_students--;
printf("删除成功!\n");
found = 1;
break;
}
}
if (!found) {
printf("未找到该学生!\n");
}
}
// 查找学生
void search_student() {
int id;
int found = 0;
printf("请输入要查询的学生学号:");
scanf("%d", &id);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id) {
printf("姓名:%s,学号:%d,成绩:%f\n", students[i].name, students[i].id, students[i].grade);
found = 1;
break;
}
}
if (!found) {
printf("未找到该学生!\n");
}
}
// 计算学生成绩
void calculate_grade() {
float sum = 0;
for (int i = 0; i < num_students; i++) {
sum += students[i].grade;
}
printf("总成绩:%f,平均成绩:%f\n", sum, sum / num_students);
}
// 成绩排名
void rank_students() {
// 复制学生数组
Student tmp_students[MAX_STUDENTS];
memcpy(tmp_students, students, sizeof(students));
// 冒泡排序
for (int i = 0; i < num_students - 1; i++) {
for (int j = 0; j < num_students - i - 1; j++) {
if (tmp_students[j].grade < tmp_students[j + 1].grade) {
Student tmp = tmp_students[j];
tmp_students[j] = tmp_students[j + 1];
tmp_students[j + 1] = tmp;
}
}
}
// 输出排名
printf("成绩排名:\n");
for (int i = 0; i < num_students; i++) {
printf("%d. %s(%d),成绩:%f\n", i + 1, tmp_students[i].name, tmp_students[i].id, tmp_students[i].grade);
}
}
// 统计等级人数
void count_grades() {
int A = 0, B = 0, C = 0, D = 0, F = 0;
for (int i = 0; i < num_students; i++) {
if (students[i].grade >= 90) {
A++;
} else if (students[i].grade >= 80) {
B++;
} else if (students[i].grade >= 70) {
C++;
} else if (students[i].grade >= 60) {
D++;
} else {
F++;
}
}
printf("等级统计:\n");
printf("A:%d,B:%d,C:%d,D:%d,F:%d\n", A, B, C, D, F);
}
// 保存数据
void save_data() {
FILE *fp = fopen("data.txt", "w");
if (fp == NULL) {
printf("无法保存数据!\n");
return;
}
fprintf(fp, "%d\n", num_students);
for (int i = 0; i < num_students; i++) {
fprintf(fp, "%s %d %f\n", students[i].name, students[i].id, students[i].grade);
}
fclose(fp);
}
// 加载数据
void load_data() {
FILE *fp = fopen("data.txt", "r");
if (fp == NULL) {
printf("无法加载数据!\n");
return;
}
fscanf(fp, "%d", &num_students);
for (int i = 0; i < num_students; i++) {
fscanf(fp, "%s %d %f", students[i].name, &students[i].id, &students[i].grade);
}
fclose(fp);
}
// 显示菜单
void show_menu() {
int choice;
do {
printf("\n");
printf("请选择操作:\n");
printf("1. 添加学生\n");
printf("2. 修改学生\n");
printf("3. 删除学生\n");
printf("4. 查找学生\n");
printf("5. 计算学生成绩\n");
printf("6. 成绩排名\n");
printf("7. 统计等级人数\n");
printf("0. 退出程序\n");
printf("请输入操作编号:");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
modify_student();
break;
case 3:
delete_student();
break;
case 4:
search_student();
break;
case 5:
calculate_grade();
break;
case 6:
rank_students();
break;
case 7:
count_grades();
break;
case 0:
printf("再见!\n");
break;
default:
printf("无效的操作编号,请重新输入。\n");
break;
}
} while (choice != 0);
}
```
以上代码实现了一个简单的学生成绩管理系统,包括学生数据输入、修改、删除、查询、计算学生成绩、成绩排名、统计等级人数、保存数据等功能。注意,这只是一个简单的示例,实际应用中可能需要更复杂的功能和更完善的错误处理。
用C语言编写一个学生成绩管理系统,要求是使用链表作为结构,实现插入,删除,修改和查询功能
好的,我了解了你的要求。以下是用C语言实现学生成绩管理系统的代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义学生结构体
typedef struct student {
char name[20];
int id;
float score;
struct student *next;
} Student;
// 新建学生节点
Student *new_student(char *name, int id, float score) {
Student *stu = (Student*)malloc(sizeof(Student));
strcpy(stu->name, name);
stu->id = id;
stu->score = score;
stu->next = NULL;
return stu;
}
// 插入学生节点
void insert_student(Student **head, Student *node) {
if (*head == NULL) {
*head = node;
return;
}
Student *cur = *head;
while (cur->next) {
cur = cur->next;
}
cur->next = node;
}
// 删除学生节点
void delete_student(Student **head, int id) {
if (*head == NULL) {
return;
}
if ((*head)->id == id) {
Student *tmp = *head;
*head = (*head)->next;
free(tmp);
return;
}
Student *cur = *head;
while (cur->next) {
if (cur->next->id == id) {
Student *tmp = cur->next;
cur->next = tmp->next;
free(tmp);
return;
}
cur = cur->next;
}
}
// 修改学生节点
void modify_student(Student **head, int id, float score) {
if (*head == NULL) {
return;
}
Student *cur = *head;
while (cur) {
if (cur->id == id) {
cur->score = score;
return;
}
cur = cur->next;
}
}
// 查询学生节点
void search_student(Student *head, int id) {
if (head == NULL) {
return;
}
Student *cur = head;
while (cur) {
if (cur->id == id) {
printf("学生姓名:%s,学号:%d,成绩:%.2f\n", cur->name, cur->id, cur->score);
return;
}
cur = cur->next;
}
}
int main() {
Student *head = NULL;
// 插入学生
insert_student(&head, new_student("张三", 1001, 80));
insert_student(&head, new_student("李四", 1002, 90));
insert_student(&head, new_student("王五", 1003, 85));
// 删除学生
delete_student(&head, 1002);
// 修改学生
modify_student(&head, 1001, 85);
// 查询学生
search_student(head, 1003);
return 0;
}
```
以上就是使用链表实现学生成绩管理系统的代码。注意,这里的代码只是一个简单的演示,实际应用中还需要完善其他功能,如输入输出、排序等。