1、构建最多可存储100个学生的信息的结构体,学生的信息包括(学号(no,char类型)、姓名(name,char类型)及数学(math,double类型)、物理(physics,double类型)、英语(english,double类型)三门成绩),完成下面内容:(1)初始化学生信息函数(Init):有3个学生,每个学生有从键盘输入每个学生的数据。(2)添加学生信息函数(Add):利用该函数,添加学生信息;(3)删除学生信息函数(Del):利用该函数,删除指定的学生;(4)输出学生信息函数(Print):输出学生信息;(5)排序(按学号排序)(Sort)(6)查找(按学号查找)(Search
时间: 2023-04-08 08:03:57 浏览: 193
):
以下是代码实现:
```c
#include <stdio.h>
#include <string.h>
#define MAX_STUDENT_NUM 100
typedef struct {
char no[10];
char name[20];
double math;
double physics;
double english;
} Student;
Student students[MAX_STUDENT_NUM];
int studentNum = 0;
void Init() {
for (int i = 0; i < 3; i++) {
printf("请输入第%d个学生的信息:\n", i + 1);
printf("学号:");
scanf("%s", students[i].no);
printf("姓名:");
scanf("%s", students[i].name);
printf("数学成绩:");
scanf("%lf", &students[i].math);
printf("物理成绩:");
scanf("%lf", &students[i].physics);
printf("英语成绩:");
scanf("%lf", &students[i].english);
studentNum++;
}
}
void Add() {
if (studentNum >= MAX_STUDENT_NUM) {
printf("学生信息已满,无法添加!\n");
return;
}
printf("请输入新学生的信息:\n");
printf("学号:");
scanf("%s", students[studentNum].no);
printf("姓名:");
scanf("%s", students[studentNum].name);
printf("数学成绩:");
scanf("%lf", &students[studentNum].math);
printf("物理成绩:");
scanf("%lf", &students[studentNum].physics);
printf("英语成绩:");
scanf("%lf", &students[studentNum].english);
studentNum++;
}
void Del() {
char no[10];
printf("请输入要删除的学生的学号:");
scanf("%s", no);
int index = -1;
for (int i = 0; i < studentNum; i++) {
if (strcmp(students[i].no, no) == 0) {
index = i;
break;
}
}
if (index == -1) {
printf("未找到该学生!\n");
return;
}
for (int i = index; i < studentNum - 1; i++) {
students[i] = students[i + 1];
}
studentNum--;
printf("删除成功!\n");
}
void Print() {
printf("学号\t姓名\t数学\t物理\t英语\n");
for (int i = 0; i < studentNum; i++) {
printf("%s\t%s\t%.2lf\t%.2lf\t%.2lf\n", students[i].no, students[i].name, students[i].math, students[i].physics, students[i].english);
}
}
void Sort() {
for (int i = 0; i < studentNum - 1; i++) {
for (int j = i + 1; j < studentNum; j++) {
if (strcmp(students[i].no, students[j].no) > 0) {
Student temp = students[i];
students[i] = students[j];
students[j] = temp;
}
}
}
printf("排序完成!\n");
}
void Search() {
char no[10];
printf("请输入要查找的学生的学号:");
scanf("%s", no);
for (int i = 0; i < studentNum; i++) {
if (strcmp(students[i].no, no) == 0) {
printf("学号\t姓名\t数学\t物理\t英语\n");
printf("%s\t%s\t%.2lf\t%.2lf\t%.2lf\n", students[i].no, students[i].name, students[i].math, students[i].physics, students[i].english);
return;
}
}
printf("未找到该学生!\n");
}
int main() {
int choice;
while (1) {
printf("请选择操作:\n");
printf("1. 初始化学生信息\n");
printf("2. 添加学生信息\n");
printf("3. 删除学生信息\n");
printf("4. 输出学生信息\n");
printf("5. 排序(按学号排序)\n");
printf("6. 查找(按学号查找)\n");
printf("0. 退出程序\n");
scanf("%d", &choice);
switch (choice) {
case 1:
Init();
break;
case 2:
Add();
break;
case 3:
Del();
break;
case 4:
Print();
break;
case 5:
Sort();
break;
case 6:
Search();
break;
case 0:
return 0;
default:
printf("无效的选择!\n");
}
}
return 0;
}
```
以上代码实现了一个简单的学生信息管理系统,可以初始化学生信息、添加学生信息、删除学生信息、输出学生信息、排序(按学号排序)、查找(按学号查找)。
阅读全文