设计一个有录取学生信息,查找学生信息,删除学生信息,修改学生信息,插入学生信息,学生成绩排名,学生人数统计,显示学生列表功能的学生信息管理系统的c语言代码
时间: 2024-03-24 11:38:55 浏览: 46
以下是一个简单的学生信息管理系统的C语言代码,包含了录入、查找、删除、修改、插入、排名和统计等功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STUDENT 100 // 最多可以录入100个学生信息
struct Student {
char name[20]; // 学生姓名
int id; // 学生学号
int score; // 学生分数
};
struct Student students[MAX_STUDENT]; // 存储学生信息的数组
int count = 0; // 当前录入学生的数量
// 录入学生信息
void addStudent() {
if (count >= MAX_STUDENT) {
printf("录入学生信息失败:已达到最大容量\n");
return;
}
struct Student student;
printf("请输入学生姓名:");
scanf("%s", student.name);
printf("请输入学生学号:");
scanf("%d", &student.id);
printf("请输入学生分数:");
scanf("%d", &student.score);
students[count] = student;
count++;
printf("录入学生信息成功\n");
}
// 查找学生信息
void findStudent() {
int id;
printf("请输入要查找的学生学号:");
scanf("%d", &id);
for (int i = 0; i < count; i++) {
if (students[i].id == id) {
printf("学生姓名:%s\n", students[i].name);
printf("学生学号:%d\n", students[i].id);
printf("学生分数:%d\n", students[i].score);
return;
}
}
printf("未找到学号为%d的学生\n", id);
}
// 删除学生信息
void deleteStudent() {
int id;
printf("请输入要删除的学生学号:");
scanf("%d", &id);
for (int i = 0; i < count; i++) {
if (students[i].id == id) {
for (int j = i; j < count - 1; j++) {
students[j] = students[j + 1];
}
count--;
printf("删除学生信息成功\n");
return;
}
}
printf("未找到学号为%d的学生\n", id);
}
// 修改学生信息
void modifyStudent() {
int id;
printf("请输入要修改的学生学号:");
scanf("%d", &id);
for (int i = 0; i < count; i++) {
if (students[i].id == id) {
struct Student student;
printf("请输入学生姓名:");
scanf("%s", student.name);
printf("请输入学生学号:");
scanf("%d", &student.id);
printf("请输入学生分数:");
scanf("%d", &student.score);
students[i] = student;
printf("修改学生信息成功\n");
return;
}
}
printf("未找到学号为%d的学生\n", id);
}
// 插入学生信息
void insertStudent() {
if (count >= MAX_STUDENT) {
printf("录入学生信息失败:已达到最大容量\n");
return;
}
int index;
printf("请输入要插入的位置(从0开始计数):");
scanf("%d", &index);
if (index < 0 || index > count) {
printf("插入学生信息失败:插入位置不合法\n");
return;
}
struct Student student;
printf("请输入学生姓名:");
scanf("%s", student.name);
printf("请输入学生学号:");
scanf("%d", &student.id);
printf("请输入学生分数:");
scanf("%d", &student.score);
for (int i = count; i > index; i--) {
students[i] = students[i - 1];
}
students[index] = student;
count++;
printf("插入学生信息成功\n");
}
// 学生成绩排名
void rankStudent() {
struct Student temp;
for (int i = 0; i < count - 1; i++) {
for (int j = i + 1; j < count; j++) {
if (students[i].score < students[j].score) {
temp = students[i];
students[i] = students[j];
students[j] = temp;
}
}
}
printf("学生排名如下:\n");
for (int i = 0; i < count; i++) {
printf("%d. %s(%d):%d分\n", i + 1, students[i].name, students[i].id, students[i].score);
}
}
// 学生人数统计
void countStudent() {
printf("当前学生总人数为%d人\n", count);
}
// 显示学生列表
void listStudent() {
printf("当前学生列表如下:\n");
for (int i = 0; i < count; i++) {
printf("%d. %s(%d):%d分\n", i + 1, students[i].name, students[i].id, students[i].score);
}
}
int main() {
int choice;
while (1) {
printf("\n学生信息管理系统\n");
printf("1. 录入学生信息\n");
printf("2. 查找学生信息\n");
printf("3. 删除学生信息\n");
printf("4. 修改学生信息\n");
printf("5. 插入学生信息\n");
printf("6. 学生成绩排名\n");
printf("7. 学生人数统计\n");
printf("8. 显示学生列表\n");
printf("0. 退出系统\n");
printf("请选择操作:");
scanf("%d", &choice);
switch (choice) {
case 1:
addStudent();
break;
case 2:
findStudent();
break;
case 3:
deleteStudent();
break;
case 4:
modifyStudent();
break;
case 5:
insertStudent();
break;
case 6:
rankStudent();
break;
case 7:
countStudent();
break;
case 8:
listStudent();
break;
case 0:
printf("感谢使用学生信息管理系统,再见!\n");
exit(0);
default:
printf("无效的选择,请重新输入\n");
break;
}
}
return 0;
}
```
通过以上代码,我们可以实现一个简单的学生信息管理系统。当然,这里只是一个示例,实际的学生信息管理系统可能需要更复杂的功能和更完善的界面设计。
阅读全文