#include <windows.h>
#include <string.h>
#include <iostream>
#include <cstdio>
using namespace std;
typedef struct node
{
char ID[100];
char name[100];
char sex;
int age;
int grades;
struct node *next;
}link;
class stu_info
{
public:
stu_info();
void show_list();
void add_list(link *l);
void add_stu();
void delete_stu();
void change_stu();
void search_stu();
void paixu();
void save();
private:
node *head;
};
char nu[100];
char nam[100];
char sc;
int ag,s;
stu_info::stu_info()
{
head=NULL;
FILE *fp;
fp=fopen("D://student.txt","rb");
if(fp==NULL)
{
printf("不存在打开文件\n");
exit(0);
}
int i=0;
while(!feof(fp))
{
char nu[100];
char nam[100];
char s;
int ag;
int sc;
fscanf(fp," %s %s %c %d %d",nu,nam,&s,&ag,&sc);
i++;
}
fclose(fp);
FILE *FP;
FP=fopen("D://student.txt","rb");
if(FP==NULL)
{
printf("无法打开文件\n");
exit(0);
}
int b=i-1;
int j=1;
while(!feof(FP))
{
fscanf(FP,"%s %s %c %d %d",nu,nam,&s,&ag,&sc);
link *n;
n=new link;
strcpy(n->ID,nu);
strcpy(n->name,nam);
n->sex=s;
n->age=ag;
n->grades=sc;
add_list(n);
n=n->next;
if(j==b)
break;
j++;
}
fclose(FP); //关闭文件
};
void stu_info::add_list(link *l)
{
l->next=head;
head=l;
}
void stu_info::show_list()
{
link *q=head;
if(q==NULL)
{
printf("还没有学生信息,请增加学生信息\n");
return;
}
while(q)
{
system("color c0");
printf(" 学号:%s \t名字:%s \t年龄:%d \t性别:%c \t总成绩:%d \n",q->ID,q->name,q->age,q->sex,q->grades);
q=q->next;
}
}
void stu_info::save()
{
FILE *fp;
link *p=head;
if((fp=fopen("D://student.txt","w"))==NULL)// 以可写的方式打开当前目录下的.txt
{
printf("不能打开此文件,请按任意键退出\n");
exit(1);
}
while(p)
{
fprintf(fp,"%s %s %c %d %d \n",p->ID,p->name,p->sex,p->age,p->grades);
p=p->next;
printf("保存成功\n");
}
fclose(fp);
}
void stu_info::search_stu()
{
int flag;
system("color b1");
printf("1.按学号查询:\n");
printf("2.按姓名查询:\n");
printf("请输入查询方式:");
scanf("%d",&flag);
if(flag==1){
printf("请输入该生学号:");
scanf("%s",nu);
link *q=head;
while(q!=NULL )
{
if(strcmp(q->ID,nu)==0)
{
printf("姓名:%s\n",q->name);
printf("学号:%s\n",q->ID);
printf("性别:%c\n",q->sex);
printf("年龄:%d\n",q->age);
printf("总成绩:%d\n",q->grades);
break;
}
q=q->next;
}
if(q==NULL)
printf("该生不存在\n");
}else{
printf("请输入该生姓名:");
scanf("%s",nam);
link *q=head;
while(q!=NULL )
{
if(strcmp(q->name,nam)==0)
{
printf("姓名:%s\n",q->name);
printf("学号:%s\n",q->ID);
printf("性别:%c\n",q->sex);
printf("年龄:%d\n",q->age);
printf("总成绩:%d\n",q->grades);
break;
}
q=q->next;
}
if(q==NULL)
printf("该生不存在\n");
}
}
void stu_info::change_stu()
{
int judge=1;
system("color e4");
printf("请输入您要修改学生的学号:\n");
scanf("%s",nu);
link *q=head;
while(q!=NULL )
{
if(strcmp(q->ID,nu)==0)
{
judge=1;
printf("请输入您要修改的信息选项:1.姓名 2. 总成绩 3.年龄 \n");
int n;
scanf("%d",&n);
switch(n)
{
case 1:
printf("请输入您要修改的名字:");
scanf("%s",nam);
printf("修改的名字为:%s\n",nam);
strcpy(q->name,nam);
printf("修改名字成功!\n");
break;
case 2:
printf("请输入您要修改的总成绩");
scanf("%d",&sc);
printf("修改的总成绩为:%d\n",sc);
q->grades=sc;
printf("修改总成绩成功!\n");
break;
case 3:
printf("请输入您要修改的年龄:");
scanf("%d",&ag);
printf("修改的年龄为:%d\n",ag);
q->age=ag;
printf("修改年龄成功!\n");
break;
default :
printf("请输入正确的选项\n");
break;
}
}
q=q->next;
}
if(judge==0)
{
printf("该生不存在\n");
}
}
void stu_info::delete_stu()
{
system("color f4");
printf("请输入您要删除的学生的学号:");
scanf("%s",nu);
//判断
link *p,*pre;
if(head==NULL)
{
printf("还没有学生信息,请增加学生信息\n");
return;
}
pre=NULL;
p=head;
int judge=0;
while(p)
{
if(strcmp(p->ID,nu)==0)
{
if(pre==NULL)
{
head=head->next;
}
else
{
pre->next =p->next;
}
judge=1;
free(p);
printf("删除学生成功\n");
break;
}
pre=p;
p=p->next;
}
if(judge==0)
printf("该生不存在\n");
}
void stu_info::add_stu()
{
system("color f2");
printf("请输入学生的信息:\n");
printf("学号:");
scanf("%s",nu);
link *q=head;
while(q!=NULL)
{
if(strcmp(q->ID,nu)==0)//判断是否存在
{
printf("该生已存在\n");
break;
}
q=q->next;
}
if(q==NULL)
{
link *p;
p=new link;
strcpy(p->ID,nu);
printf("姓名:") ;
scanf("%s",nam) ;
strcpy(p->name,nam);
printf("性别:(m为男 w为女)");
scanf(" %c",&s);
p->sex=s;
printf("年龄:");
scanf("%d",&ag);
p->age=ag;
printf("总成绩:");
scanf("%d",&sc);
while(sc>100||sc<0){
printf("输入有误,请重新输入\n");
scanf("%d",&sc);
}
p->grades=sc;
add_list(p);
}
}
void stu_info::paixu()
{
system("color f9");
link *q,*p,*r=head;
//判断
if(r==NULL)
{
printf("还没有学生信息,请增加学生信息\n");
return;
}
while(r) //两层循环完成排序
{
p=r;
q=r->next;
link *tmp;//用于排序时暂存节点
tmp=new link;
while(q)
{
if(q->grades > p->grades)
{
/*先复制q结点信息到tmp*/
strcpy(tmp->ID,q->ID);
strcpy(tmp->name,q->name);
tmp->sex=q->sex;
tmp->age=q->age;
tmp->grades=q->grades;
/*再复制p结点信息到q*/
strcpy(q->ID,p->ID);
strcpy(q->name,p->name);
q->sex=p->sex;
q->age=p->age;
q->grades=p->grades;
/*最后复制exchange结点信息到p*/
strcpy(p->ID,tmp->ID);
strcpy(p->name,tmp->name);
p->sex=tmp->sex;
p->age=tmp->age;
p->grades=tmp->grades;
}
q=q->next;
}
r=r->next;
}
printf("排序后的学生信息是:\n");
show_list();
}
void welocome()//登陆界面
{
system("color b1");
printf("````````````````````````````````````````````````````````````````````````````````");
printf("\n");
printf("\n");
printf("\n");
printf(" *********************** 欢迎登录学生信息管理平台 ************************* \n");
printf("\n");
printf("\n");
printf("\n");
printf("````````````````````````````````````````````````````````````````````````````````\n");
}
void menu()//功能菜单
{
system("color e3");
printf(" |________________________________________________|\n");
printf(" | |\n");
printf(" | 学生信息管理系统 |\n");
printf(" | |\n");
printf(" | 0、退出系统 |\n");
printf(" | 1、增加学生信息 |\n");
printf(" | 2、删除学生信息 |\n");
printf(" | 3、修改学生信息 |\n");
printf(" | 4、查找学生的信息 |\n");
printf(" | 5、按照学生成绩排序 |\n");
printf(" | 6、浏览全部学生信息 |\n");
printf(" | 7、保存学生信息到文件 |\n");
printf(" | |\n");
printf(" |________________________________________________|\n");
return ;
}
int main()
{
system("cls");
stu_info lg;
welocome();
Sleep(1000);//延时一秒
int choose;
while(1)
{
menu();//功能菜单
printf("请输入您要选择的功能键:\n");
scanf("%d",&choose);
switch(choose)
{
case 0://退出
printf("谢谢使用!欢迎下次光临");
exit(0);
case 1://增加学生信息
lg.add_stu();//增加新的学生
break;
case 2://删除所有学生信息
lg.delete_stu();//删除学生
break;
case 3://改变个学生的信息
lg.change_stu();//改变学生信息
break;
case 4://查找某个学生的信息
lg.search_stu();//按学号查找学生并输出该生信息
break;
case 5:// 对学生成绩进行排序
lg.paixu();
break;
case 6://输出所有学生的信息
lg.show_list();
break;
case 7://保存学生信息到文件
lg.save();
break;
default:
printf("请输入正确的选择\n");
break;
}
}
return 0;
}
运行后界面如下图: