最新C语言之学生管理系统.docx
- 文档编号:2145748
- 上传时间:2022-10-27
- 格式:DOCX
- 页数:19
- 大小:135.90KB
最新C语言之学生管理系统.docx
《最新C语言之学生管理系统.docx》由会员分享,可在线阅读,更多相关《最新C语言之学生管理系统.docx(19页珍藏版)》请在冰豆网上搜索。
最新C语言之学生管理系统
流程图:
运行结果:
程序源码:
#include
#include
#include
#include
#include
#defineLENsizeof(structstudent)//求字节数运算符
structstudent
{
charname[20];
longintnum;
charsex[4];
intage;
charaddress[30];
floatscore;
structstudent*next;//链表
};//定义一个结构题
intTOTAL_NUM=0;//学生总数
structstudent*head=NULL;
voidmainmenu();//主界面
voidrecord();//记录数据
voidinsert(structstudent*stu);//插入数据
voiddisplay(structstudent*stu);//显示一个学生的信息
voiddisplayAll();//显示所有学生的信息
voidquery();//查询学生信息
voidquery_by_num();//按学号查询学生信息
voidquery_by_name();
voidreadData();//读取文件里学生的信息
voidwriteData();//向文件写入学生信息
voidfreeAll();//清空链表内容
voiddel();//删除学生信息
voidchange();//更改学生信息
voidsort();//排序
voiddevise(structstudent*p);//选择更改内容
intmain(void)
{
mainmenu();
return0;
}
//系统主菜单
voidmainmenu()
{
intchoice;
choice=-1;
readData();
printf("\t\t\t----------------------------------------------------\n");
printf("\t\t\t|欢迎使用通信工程专业学生信息管理系统|\n");
printf("\t\t\t----------------------------------------------------\n");
printf("\t\t\t本程序需要在当前目录下建立student.txt才可正常运行\n");
do
{
printf("\n\n\n");
printf("\t\t\t--------------------------------------------\n");
printf("\t\t\t通信工程专业学生信息管理系统|\n");
printf("\t\t\t--------------------------------------------\n");
printf("\t\t\t[1]----录入学生信息|\n");
printf("\t\t\t[2]----浏览学生信息|\n");
printf("\t\t\t[3]----查询学生信息|\n");
printf("\t\t\t[4]----删除学生信息|\n");
printf("\t\t\t[5]----修改学生信息|\n");
printf("\t\t\t[6]----排序|\n");
printf("\t\t\t[0]----退出系统|\n");
printf("\t\t\t--------------------------------------------\n");
printf("请输入您的选择");
scanf("%d",&choice);
switch(choice)
{
case0:
writeData();freeAll();exit(0);
case1:
record();break;
case2:
displayAll();break;
case3:
query();break;
case4:
del();break;
case5:
change();break;
case6:
sort();break;
default:
printf("\n无效选项!
");break;
}
}while(choice!
=0);
}
//录入学生信息
voidrecord()
{
structstudent*p0;
p0=(structstudent*)malloc(LEN);
printf("\t\t\t请输入学生的姓名:
");
scanf("%s",p0->name);
printf("\t\t\t请输入学生的学号:
");
scanf("%ld",&p0->num);
printf("\t\t\t请输入学生的性别:
");
scanf("%s",p0->sex);
printf("\t\t\t请输入学生的年龄:
");
scanf("%d",&p0->age);
printf("\t\t\t请输入学生的地址:
");
scanf("%s",p0->address);
printf("\t\t\t请输入学生的成绩:
");
scanf("%f",&p0->score);
insert(p0);
printf("\t\t\t该学生的信息为:
\n");
printf("\t\t\t-------------------------------------------------------------------------------\n");
printf("\t\t\t姓名\t学号\t\t年龄\t性别\t地址\t\t成绩\n");
display(p0);
}
voidinsert(structstudent*stu)
{
structstudent*p0,*p1,*p2;
p1=head;
p0=stu;
if(head==NULL)
{
head=p0;
p0->next=NULL;
}
else
{
while((p0->num>p1->num)&&(p1->next!
=NULL))
{
p2=p1;p1=p1->next;
}
if(p0->num<=p1->num)
{
if(head==p1)
head=p0;
else
p2->next=p0;
p0->next=p1;
}
else
{
p1->next=p0;
p0->next=NULL;
}
}
TOTAL_NUM++;
}
voiddisplay(structstudent*p)
{
printf("\t\t\t%s\t%ld\t\t%d\t%s\t%s\t\t%f\n",p->name,p->num,p->age,p->sex,p->address,p->score);
}
//浏览学生信息
voiddisplayAll()
{
structstudent*p;
printf("\t\t\t学生总数:
%d\n",TOTAL_NUM);
p=head;
if(head!
=NULL)
{
printf("\t\t\t姓名\t学号\t\t年龄\t性别\t地址\t\t成绩\n");
printf("\t\t\t-------------------------------------------------------------------------------\n");
do
{
display(p);
p=p->next;
}
while(p!
=NULL);
}
printf("\n");
}
voidquery()
{
intchoice;
choice=-1;
do
{
printf("\n");
printf("--------------------\n");
printf("|按学号查询请按1|\n");
printf("|按姓名查询请按2|\n");
printf("|取消请按0|\n");
printf("+--------------------+\n");
printf("请输入您的选择");
scanf("%d",&choice);
switch(choice)
{
case0:
return;
case1:
query_by_num();break;
case2:
query_by_name();break;
default:
printf("\n无效选项!
");break;
}
}
while(choice!
=0);
}
//按姓名查询学生信息
voidquery_by_name()
{
charname[20];
structstudent*p1;
printf("请输入学生的姓名");
scanf("%s",name);
if(head==NULL)
{printf("无学生记录\n");
return;
}
p1=head;
while(strcmp(name,p1->name)&&p1->next!
=NULL)
p1=p1->next;
if(!
strcmp(name,p1->name))
{
printf("\t\t\t姓名\t学号\t\t年龄\t性别\t地址\t\t成绩\n");
printf("\t\t\t-------------------------------------------------------------------------------\n");
display(p1);
}
else
printf("没有该学生记录请核对");
}
//按学号查询学生信息
voidquery_by_num()
{
intnum;
structstudent*p1;
printf("请输入学生的学号");
scanf("%ld",&num);
if(head==NULL)
{
printf("无学生记录\n");
return;
}
p1=head;
wh
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 最新 语言 学生 管理 系统