完成学生信息管理系统
要求:定义一个班级,包括多个学生,以及记录实际学生的个数
1> 完成班级的创建,创建时,需要传递班级实际人数
2> 完成班级学生的信息录入工作
3> 完成将班级学生按成绩进行降序排序工作
4> 输出班级中成绩最好和最差学生的信息
5> 完成信息的输出工作
6> 完成班级的销毁工作
要求:班级创建在堆区,尽量分文件编译完成
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAX 30
struct Stu
{
char Name[20];
char Gender[20];
double score;
};
struct Class{
struct Stu student[MAX];
int size;
}one;
void caidan() {
printf("\t\t\t\t*******************学生管理系统*************************\t\t\t\n");
printf("\t\t\t\t***功能1:输入学生信息**********功能2:输出学生信息*******\t\t\t\n");
printf("\t\t\t\t***功能3:最优和最差学生信息**** 功能4:学生信息排序**********\t\n");
printf("\t\t\t\t***功能5:销毁班级********功能0:退出*********************\t\t\t\n");
}
struct Class * fun(int n) {
struct Class * p = malloc(sizeof(struct Stu)*n);
if (NULL == p) {
printf("录入班级人数失败");
}
else
printf("录入班级人数成功");
memset(p, 0, sizeof(struct Stu)*n);
return p;
}
void fun1(struct Class * p, int n) {
if(NULL == p)
{
printf("录入失败\n");
return ;
}
else
for (int i = 0; i < n; i++) {
printf("请输入第%d个学生的姓名",i+1);
scanf("%s", p->student[i].Name);
printf("请输入第%d个学生的性别", i+1);
scanf("%s", p->student[i].Gender);
printf("请输入第%d个学生的成绩",i+1);
scanf("%lf", &p->student[i].score);
}
printf("输入成功");
printf("\n");
}
void fun2(struct Class* p, int n) {
for (int i = 0; i < n; i++) {
printf("%s\t%s\t%.2lf", p->student[i].Name, p->student[i].Gender, p->student[i].score);
printf("\n");
}
printf("输出成功");
printf("\n");
}
void fun3(struct Class* p, int n) {
int a, b;
for (int i = 0; i < n-1; i++) {
if (p->student[i].score < p->student[i+1].score) {
a = i + 1;
}
}
for (int i = 0; i < n-1; i++) {
if (p->student[i].score > p->student[i+1].score) {
b = i + 1;
}
}
printf("%s\t%s\t%.1lf\t\n", p->student[a].Name, p->student[a].Gender, p->student[a].score);
printf("%s\t%s\t%.1lf\t\n", p->student[b].Name, p->student[b].Gender, p->student[b].score);
}
void fun4(struct Class * arr, int n) {
for (int i = 1; i < n; i++)
{
for (int j = 0; j < n - i; j++)
{
if (arr->student[j].score > arr->student[j+1].score)
{
int temp = arr->student[j+1].score;
arr->student[j+1].score = arr->student[j].score;
arr->student[j].score = temp;
}
}
}
printf("排序成功!");
printf("\n");
}
void fun5(struct Class* p)
{
//释放内存
if (NULL != p)
{
free(p); //释放空间
p = NULL;
}
printf("销毁成功!");
}
int main() {
int a = 0;
printf("请输入班级人数:");
scanf("%d",&one.size);
struct Class * p = fun(one.size);
while (1) {
caidan();
scanf("%d", &a);
switch (a)
{
case 1: {
fun1(p, one.size);
}break;
case 2: {
fun2(p, one.size);
}break;
case 3: {
fun3(p, one.size);
}break;
case 4: {
fun4(p, one.size);
}break;
case 5: {
fun5(p);
p=NULL;
}break;
case 0: goto END;
default:
printf("您输入有误");
}
}
END:
printf("\n");
}