简单学生成绩管理系统
时间: 2023-12-22 18:28:06 浏览: 20
以下是一个简单的学生成绩管理系统的C语言代码实现,具体功能包括学生信息录入、成绩录入、成绩查询、成绩排序等:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_NUM 100 // 最大学生数
// 学生结构体
typedef struct {
char name[20]; // 姓名
int num; // 学号
int score; // 成绩
} Student;
// 学生数组
Student students[MAX_NUM];
// 学生数量
int num = 0;
// 添加学生
void addStudent() {
if (num >= MAX_NUM) {
printf("学生数量已达到最大值,无法添加!\n");
return;
}
printf("请输入学生姓名:");
scanf("%s", students[num].name);
printf("请输入学生学号:");
scanf("%d", &students[num].num);
printf("请输入学生成绩:");
scanf("%d", &students[num].score);
num++;
printf("添加成功!\n");
}
// 查询学生
void queryStudent() {
int num;
printf("请输入要查询的学生学号:");
scanf("%d", &num);
for (int i = 0; i < MAX_NUM; i++) {
if (students[i].num == num) {
printf("姓名:%s,学号:%d,成绩:%d\n", students[i].name, students[i].num, students[i].score);
return;
}
}
printf("未找到该学生!\n");
}
// 排序学生
void sortStudent() {
for (int i = 0; i < num - 1; i++) {
for (int j = 0; j < num - i - 1; j++) {
if (students[j].score < students[j + 1].score) {
Student temp = students[j];
students[j] = students[j + 1];
students[j + 1] = temp;
}
}
}
printf("排序成功!\n");
}
// 显示所有学生
void showAllStudents() {
printf("姓名\t学号\t成绩\n");
for (int i = 0; i < num; i++) {
printf("%s\t%d\t%d\n", students[i].name, students[i].num, students[i].score);
}
}
int main() {
while (1) {
printf("请选择操作:\n");
printf("1.添加学生\n");
printf("2.查询学生\n");
printf("3.排序学生\n");
printf("4.显示所有学生\n");
printf("5.退出\n");
int choice;
scanf("%d", &choice);
switch (choice) {
case 1:
addStudent();
break;
case 2:
queryStudent();
break;
case 3:
sortStudent();
break;
case 4:
showAllStudents();
break;
case 5:
exit(0);
default:
printf("无效的操作!\n");
break;
}
}
return 0;
}
```