用c语言写学生成绩管理系统要求实现按学号查找并显示学生成绩信息
时间: 2023-06-19 20:07:40 浏览: 585
好的,这里给您提供一个简单的 C 语言示例代码,实现按学号查找并显示学生成绩信息的功能。
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STUDENT_NUM 100 // 最大学生数
#define MAX_NAME_LEN 20 // 最大姓名长度
#define MAX_SCORE_NUM 3 // 最大科目数
// 定义学生信息结构体
typedef struct {
int id; // 学号
char name[MAX_NAME_LEN]; // 姓名
float scores[MAX_SCORE_NUM]; // 成绩数组
} Student;
// 定义学生数组和学生数目
Student students[MAX_STUDENT_NUM];
int studentNum = 0;
// 添加一个学生
void addStudent() {
if (studentNum >= MAX_STUDENT_NUM) {
printf("学生数目已达到最大值,无法添加!\n");
return;
}
Student newStudent;
printf("请输入学生信息:\n");
printf("学号:");
scanf("%d", &newStudent.id);
printf("姓名:");
scanf("%s", newStudent.name);
for (int i = 0; i < MAX_SCORE_NUM; i++) {
printf("科目%d成绩:", i + 1);
scanf("%f", &newStudent.scores[i]);
}
students[studentNum] = newStudent;
studentNum++;
}
// 按学号查找学生并显示学生信息
void findStudentById() {
int id;
printf("请输入要查找的学生学号:");
scanf("%d", &id);
for (int i = 0; i < studentNum; i++) {
if (id == students[i].id) {
printf("学号:%d 姓名:%s 科目1成绩:%f 科目2成绩:%f 科目3成绩:%f\n",
students[i].id, students[i].name, students[i].scores[0], students[i].scores[1], students[i].scores[2]);
return;
}
}
printf("未找到该学生!\n");
}
// 主函数
int main() {
int choice;
while (1) {
printf("请选择操作:\n");
printf("1. 添加学生\n");
printf("2. 按学号查找并显示学生信息\n");
printf("3. 退出程序\n");
scanf("%d", &choice);
switch (choice) {
case 1:
addStudent();
break;
case 2:
findStudentById();
break;
case 3:
printf("程序已退出!\n");
return 0;
default:
printf("无效的操作!\n");
break;
}
}
return 0;
}
```
这个程序中,我们定义了一个 `Student` 结构体,其中包含了学生的学号、姓名和成绩数组。我们通过一个学生数组 `students` 来存储所有学生信息,同时还定义了一个 `studentNum` 变量来记录学生数量。通过添加学生和按学号查找学生两个操作,实现了一个简单的学生成绩管理系统。
阅读全文