//main()函数
#include "fun.h"
int menu()
{
int i;
//printf("请按任意键开始.......");
printf("|------------------请选择(数字)----------------|/n");
printf("| 1---查看所有学生信息. |/n");
printf("| 2---按成绩顺序查看学生信息. |/n");
printf("| 3---添加一个学生信息. |/n");
printf("| 4---删除一个学生信息. |/n");
printf("| 5---保存所有学生信息到文件并退出. |/n");
printf("|----------------------------------------------|/n");
scanf("%d",&i);
return i;
}
int main()
{
struct btree Q[MAXSIZE+1];
//char buf[sizeof(struct STU)];
struct STU stu;
int cmd,i,j,n,ISchange=0;
//初始化 Q[]
for(i=0;i<=MAXSIZE;i++) {Q[i].left=0;Q[i].right=0;}
readSTU(Q,MAXSIZE);
printf("********已经从文件读出数据%d个**********/n",COUNT);
while(1)
{ while(1){
cmd=menu();
if(cmd>0&&cmd<6) break;
}
// 1 ................................
if(cmd==1)//直接显示所有信息
{
printf("******现在记录有学生%d名*******/n",COUNT);
for(i=1;i<=COUNT;i++)
{
printf("ID:- ",i);
show(Q[i]);
}
}
else if(cmd==2)//按成绩排序
{
for(i=1;i<=COUNT;i++) printf("btree[%d]---s[]cj=%d...LR(%d,%d)./n",i,Q[i].data.cj,Q[i].left,Q[i].right);
printf("*******学生人数为(按成绩排列):%d********/n",COUNT);
sortbt(Q,Q[1]);
}
else if(cmd==3)//添加一个学生消息
{
printf("请按姓名,年龄,班级,成绩的顺序输入学生信息(注意格式:空格隔开):/n");
scanf("%s%d%s%d",stu.name,&stu.age,stu.ban,&stu.cj);
ins(Q,stu);
ISchange=1;
printf("添加后学生人数为:%d/n",COUNT);
}
else if(cmd==4)
{
printf("输入要删除的学生的ID号:");
scanf("%d",&n);
if(n<1||n>COUNT) printf("No such student!please enter again:/n");
else{//i 是要删除学生的ID
printf("ID为%d的学生已经被删除./n",n);
i=COUNT;//i is old COUNT
COUNT=0;//强制为0
for(j=1;j<=i;j++) if(j!=n) ins(Q,Q[j].data);
printf("删除一个后学生人数为:%d/n",COUNT);
ISchange=1;
}
}
else if(cmd==5)
{
printf("将要保存到文件的学生人数为:%d/n",COUNT);
if(ISchange) saveSTU(Q);
return 0;
}
}
}