用DevC++编程设计学生结构体student(包括三个成员:学号,姓名,成绩),创建学生数组stu[6],完成以下四个功能:能向学生数组中添加学生信息,能在学生数组中按照姓名查找学生信息,能向学生数组中按照学生号删除学生信息,能在学生数组中按照成绩从小到大排序
时间: 2024-01-02 13:02:40 浏览: 84
好的,我会尽力解答。这是一个比较复杂的问题,需要用到结构体、数组和排序算法。以下是代码实现:
```c
#include <stdio.h>
#include <string.h>
#define MAX_STUDENT 6 // 学生数组的最大长度
// 学生结构体
typedef struct {
int id; // 学号
char name[20]; // 姓名
int score; // 成绩
} Student;
// 添加学生信息的函数
void addStudent(Student stu[], int *size) {
if (*size >= MAX_STUDENT) {
printf("学生数组已满,无法添加新学生!\n");
return;
}
printf("请输入学生信息:\n");
printf("学号:");
scanf("%d", &stu[*size].id);
printf("姓名:");
scanf("%s", stu[*size].name);
printf("成绩:");
scanf("%d", &stu[*size].score);
(*size)++; // 学生数组长度加1
}
// 按照姓名查找学生信息的函数
void searchByName(Student stu[], int size) {
char name[20];
printf("请输入要查找的学生姓名:");
scanf("%s", name);
int found = 0;
for (int i = 0; i < size; i++) {
if (strcmp(stu[i].name, name) == 0) { // 如果找到了
printf("学号:%d,姓名:%s,成绩:%d\n", stu[i].id, stu[i].name, stu[i].score);
found = 1;
break;
}
}
if (!found) {
printf("没有找到姓名为%s的学生!\n", name);
}
}
// 按照学号删除学生信息的函数
void deleteById(Student stu[], int *size) {
int id;
printf("请输入要删除的学生学号:");
scanf("%d", &id);
int found = 0;
for (int i = 0; i < *size; i++) {
if (stu[i].id == id) { // 如果找到了
for (int j = i; j < (*size) - 1; j++) { // 把后面的元素前移
stu[j] = stu[j + 1];
}
(*size)--; // 学生数组长度减1
printf("已删除学号为%d的学生!\n", id);
found = 1;
break;
}
}
if (!found) {
printf("没有找到学号为%d的学生!\n", id);
}
}
// 按照成绩从小到大排序的函数
void sortByScore(Student stu[], int size) {
for (int i = 0; i < size - 1; i++) {
for (int j = i + 1; j < size; j++) {
if (stu[i].score > stu[j].score) { // 如果前面的成绩比后面的成绩大
Student temp = stu[i]; // 交换两个元素
stu[i] = stu[j];
stu[j] = temp;
}
}
}
printf("按照成绩从小到大排序后的学生信息:\n");
for (int i = 0; i < size; i++) {
printf("学号:%d,姓名:%s,成绩:%d\n", stu[i].id, stu[i].name, stu[i].score);
}
}
// 主函数
int main() {
Student stu[MAX_STUDENT]; // 学生数组
int size = 0; // 学生数组的长度
while (1) {
printf("请选择要执行的操作:\n");
printf("1. 添加学生信息\n");
printf("2. 按照姓名查找学生信息\n");
printf("3. 按照学号删除学生信息\n");
printf("4. 按照成绩从小到大排序\n");
printf("5. 退出程序\n");
printf("请输入操作编号:");
int choice;
scanf("%d", &choice);
switch (choice) {
case 1:
addStudent(stu, &size);
break;
case 2:
searchByName(stu, size);
break;
case 3:
deleteById(stu, &size);
break;
case 4:
sortByScore(stu, size);
break;
case 5:
printf("程序已退出!\n");
return 0;
default:
printf("无效的操作编号,请重新输入!\n");
}
}
}
```
以上代码中,我们定义了一个学生结构体,包括学号、姓名和成绩三个成员。我们通过一个学生数组来存储多个学生的信息。然后,我们实现了四个功能:添加学生信息、按照姓名查找学生信息、按照学号删除学生信息、按照成绩从小到大排序。我们还利用了一个 while 循环,让用户可以反复执行这些功能,直到用户选择退出程序。希望这个例子可以帮助你理解结构体、数组和排序算法的用法。
阅读全文