主程序代码
#include "test.h"
int main(int argc, char const *argv[])
{
int n=0;struct Class *p=NULL;
while(1)
{
printf("\n");
int a=0;
print_menu();
printf("输入功能选项:");
scanf("%d",&a);
switch(a)
{
case 1:
{
printf("输入班级人数:");
scanf("%d",&n);
p=creat(n);
}
break;
case 2:
{
input(p);
}
break;
case 3:
{
sort(p);
}
break;
case 4:
{
bestworst(p);
}
break;
case 5:
{
output(p);
}
break;
case 6:
{
int n=0;
printf("输入要插入的位置:");
scanf("%d",&n);
insert(p,n);
}
break;
case 7:
{
char n[20]="";
printf("输入要删除的学生姓名:");
scanf("%s",n);
delete(p,n);
}
break;
case 8:
{
char n[20]="";
printf("输入要修改的学生姓名:");
scanf("%s",n);
update(p,n);
}
break;
case 9:
{
char n[20]="";
printf("输入要查找的学生姓名:");
scanf("%s",n);
search(p,n);
}
break;
case 10:
{
destroy(&p);
}
break;
case 0:
{
printf("退出成功\n");
return 0;
}
break;
default:
printf("输入错误\n");
break;
}
}
}
源文件代码
#include "test.h"
struct Class *creat(int n)
{
struct Class *ptr=(struct Class*)malloc(sizeof(struct Class));
memset(ptr,0,sizeof(struct Class));
ptr->size=n;
if(NULL==ptr||n<0||n>MAX)
{
printf("创建失败\n");
return NULL;
}
printf("创建成功\n");
return ptr;
}
int empty(struct Class *ptr)
{
return ptr->size==0;
}
int full(struct Class *ptr)
{
return ptr->size==MAX;
}
void input(struct Class *ptr)
{
for(int i=0;i<ptr->size;i++)
{
printf("输入第%d位学生信息:\n",i+1);
printf("姓名:");
scanf("%s",ptr->student[i].name);
printf("年龄:");
scanf("%d",&ptr->student[i].age);
printf("成绩:");
scanf("%lf",&ptr->student[i].score);
printf("\n");
}
}
int sort(struct Class *ptr)
{
if(NULL==ptr||empty(ptr))
{
printf("排序失败\n");
return -1;
}
for(int i=1;i<ptr->size;i++)
{
for(int j=0;j<ptr->size-i;j++)
{
if(ptr->student[j].score<ptr->student[j+1].score)
{
struct Stu temp=ptr->student[j];
ptr->student[j]=ptr->student[j+1];
ptr->student[j+1]=temp;
}
}
}
printf("姓名\t年龄\t成绩\n");
for(int i=0;i<ptr->size;i++)
{
printf("%s\t%d\t%.2lf\n",ptr->student[i].name,ptr->student[i].age,ptr->student[i].score);
}
}
int bestworst(struct Class *ptr)
{
if(NULL==ptr||empty(ptr))
{
printf("查找失败\n");
return -1;
}
int min=ptr->student[0].score,max=ptr->student[0].score;
int mini=0,maxi=0;
for(int i=0;i<ptr->size;i++)
{
if(min>ptr->student[i].score)
{
min=ptr->student[i].score;
mini=i;
}
if(max<ptr->student[i].score)
{
max=ptr->student[i].score;
maxi=i;
}
}
printf("成绩最高学生信息:\n");
printf("姓名\t年龄\t成绩\n");
printf("%s\t%d\t%.2lf\n",ptr->student[maxi].name,ptr->student[maxi].age,ptr->student[maxi].score);
printf("\n");
printf("成绩最低学生信息:\n");
printf("姓名\t年龄\t成绩\n");
printf("%s\t%d\t%.2lf\n",ptr->student[mini].name,ptr->student[mini].age,ptr->student[mini].score);
}
int output(struct Class *ptr)
{
if(NULL==ptr||empty(ptr))
{
printf("输出失败\n");
return -1;
}
printf("姓名\t年龄\t成绩\n");
for(int i=0;i<ptr->size;i++)
{
printf("%s\t%d\t%.2lf\n",ptr->student[i].name,ptr->student[i].age,ptr->student[i].score);
}
}
void destroy(struct Class **ptr)
{
if(NULL!=*ptr)
{
free(*ptr);
*ptr=NULL;
}
printf("销毁成功\n");
}
int insert(struct Class *ptr,int pos)
{
if(NULL==ptr||full(ptr)||pos<0||pos>=MAX)
{
printf("插入失败\n");
return -1;
}
for(int i=ptr->size-1;i>=pos;i--)
{
ptr->student[i+1]=ptr->student[i];
}
printf("输入要插入的学生姓名:");
scanf("%s",ptr->student[pos].name);
printf("输入要插入的学生年龄:");
scanf("%d",&ptr->student[pos].age);
printf("输入要插入的学生成绩:");
scanf("%lf",&ptr->student[pos].score);
ptr->size++;
printf("插入成功:\n");
return 0;
}
int delete(struct Class *ptr,char *n)
{
int pos=-1;
if(NULL==ptr||empty(ptr))
{
printf("删除失败\n");
return -1;
}
for(int i=0;i<ptr->size;i++)
{
if(strcmp(ptr->student[i].name,n)==0)
{
pos=i;
break;
}
}
if(pos==-1)
{
printf("班里没有此人,删除失败\n");
return -1;
}
for(int i=pos;i<ptr->size;i++)
{
ptr->student[i]=ptr->student[i+1];
}
ptr->size--;
printf("删除成功\n");
return 0;
}
int update(struct Class *ptr,char *n)
{
if(NULL==ptr||empty(ptr))
{
printf("修改失败\n");
return -1;
}
for(int i=0;i<ptr->size;i++)
{
if(strcmp(ptr->student[i].name,n)==0)
{
printf("输入修改后的姓名:");
scanf("%s",ptr->student[i].name);
printf("输入修改后的年龄:");
scanf("%d",&ptr->student[i].age);
printf("输入修改后的成绩:");
scanf("%lf",&ptr->student[i].score);
printf("修改成功\n");
return 0;
}
}
printf("没有此人信息\n");
return -1;
}
int search(struct Class *ptr,char *n)
{
if(NULL==ptr||empty(ptr))
{
printf("删除失败\n");
return -1;
}
for(int i=0;i<ptr->size;i++)
{
if(strcmp(ptr->student[i].name,n)==0)
{
printf("姓名\t年龄\t成绩\n");
printf("%s\t%d\t%.2lf\n",ptr->student[i].name,ptr->student[i].age,ptr->student[i].score);
return 0;
}
}
printf("没有此人信息\n");
return -1;
}
void print_menu()
{
printf("\t\t***************学生管理系统*************\n");
printf("\t\t输入1创建班级,传递班级人数---------------\n");
printf("\t\t输入2录入学生信息------------------------\n");
printf("\t\t输入3对学生信息按成绩降序排序--------------\n");
printf("\t\t输入4输出成绩最高和最低学生信息------------\n");
printf("\t\t输入5输出学生信息------------------------\n");
printf("\t\t输入6插入学生信息------------------------\n");
printf("\t\t输入7删除学生信息------------------------\n");
printf("\t\t输入8修改学生信息------------------------\n");
printf("\t\t输入9查找学生信息------------------------\n");
printf("\t\t输入10班级销毁---------------------------\n");
printf("\t\t输入0退出-----------------------------=-\n");
printf("\n");
}
文件代码
#ifndef TEST_H
#define TEST_H
#include<myhead.h>
#define MAX 100
struct Stu
{
char name[20];
int age;
double score;
};
struct Class
{
struct Stu student[MAX];
int size;
};
struct Class *creat(int n);
int empty(struct Class *ptr);
int full(struct Class *ptr);
void input(struct Class *ptr);
int sort(struct Class *ptr);
int bestworst(struct Class *ptr);
int output(struct Class *ptr);
void destroy(struct Class **ptr);
int insert(struct Class *ptr,int pos);
int delete(struct Class *ptr,char *n);
int update(struct Class *ptr,char *n);
int search(struct Class *ptr,char *n);
void print_menu();
#endif