学生成绩管理系统c语言代码供参考.docx

上传人:b****5 文档编号:3537438 上传时间:2022-11-23 格式:DOCX 页数:12 大小:37.22KB
下载 相关 举报
学生成绩管理系统c语言代码供参考.docx_第1页
第1页 / 共12页
学生成绩管理系统c语言代码供参考.docx_第2页
第2页 / 共12页
学生成绩管理系统c语言代码供参考.docx_第3页
第3页 / 共12页
学生成绩管理系统c语言代码供参考.docx_第4页
第4页 / 共12页
学生成绩管理系统c语言代码供参考.docx_第5页
第5页 / 共12页
点击查看更多>>
下载资源
资源描述

学生成绩管理系统c语言代码供参考.docx

《学生成绩管理系统c语言代码供参考.docx》由会员分享,可在线阅读,更多相关《学生成绩管理系统c语言代码供参考.docx(12页珍藏版)》请在冰豆网上搜索。

学生成绩管理系统c语言代码供参考.docx

学生成绩管理系统c语言代码供参考

C程序学生管理系统

欧阳光明(2021.03.07)

以下是用C语言编写的学生成绩管理系统的简单代码,可以用VC运行(供参考)

#include"stdio.h"

#includenstdlib.hM

#includenstring.hn

typedefstructstudent//定义学生

{

charname[10];

intnumber;

charsex[2];

intmath;

integlish;

intclanguge;

intaverage;

}student;

typedefstructunit//定义接点

{

studentdate;

structunit*next;

}unit;

unit*build()〃建立链表并返回指针

{

unit*p;

if((p=(unit*)malloc(sizeof(unit)))==NULL)

{printf(n=>初始化失败!

”);

return0;

1

else

{p->next=NULL;

p->date.number=0;//头结点存放学生人数

printf(”初始化成功!

\n“);

returnp;

1

voidadd(unit*head)//增加学生

{

unit*p,*q;

intm,n=0;

q=head->next;

p=(unit*)malloc(sizeof(unit));

printfC'=>请输入新生姓名!

\n“);

gets(p->date.name);fflush(stdin);

水欧阳光明*创编2021.03.07

*欧阳光明*创编2021.03.07

printf(”二〉请输入学号!

\n“);

while(n==0)

{

scanf("%d'',&m);fflush(stdin);

if(q二二NULL)n二1;

while(q)

{

if(q->date.number==m)

{

printf("=>你输入的学号与已有同学的学号相同,

请重新输入!

\『);

q=head->next;

break;

else

{

q=q->next;

if(q二二NULL)n=l;

p->date.number=m;

printf(“=>请输入性别!

\n”);

水欧阳光明*创编

*欧阳光明*创编2021.03.07

gets(p->date.sex);fflush(stdin);

printf("=>请输入数学成绩\n”);

scanf("%d",&m);fflush(stdin);

p->date.math=m;

printf(M=>请输入英语成绩\n”);

scanf("%d",&m);fflush(stdin);

p->date.eglish=m;

printf(H=>请输入c语言成绩\n”);

scanf("%d",&m);fflush(stdin);

p->date.clanguge=m;

p->date.average=(p->date.math+p->date.eglish+p->date.clanguge);

q=head->next;

head->next=p;

p->next=q;

head->date.number++;

voiddeletion(unit*head)//删除—名学生

{

unit*p=head->next,*q=head;

charN[10];

printfC'=>请输入你想删除的学生姓名!

\n“);

gets(N);fflush(stdin);

if(p==NULL)

printf(”二〉系统无学生可删除!

\n“);

while(p)

{

if(strcmp(p->date.name,N)==O)

{

q->next=p・>next;

head->date.number—;

printf("=>删除%s成功!

\n",p->date.name);

free(p);

break;

else

{

p=p->next;

q=q->next;

if(p==NULL)

printf(你要删除的学生不存在,删除失贩!

W);

intdisplay(unit*head)//显示学生信息

{

unit*p=head->next;

水欧阳光明*创编2021.03.07

intm,n=O;

charN[10];

if(p==NULL)

{

printf("=>系统无学生!

\nM);

return0;

printf(

while(n==0)

11*1#•土*1**1^•士*1*■士%V*!

•*1*%L*

叶."J、"j、"Q"J*%、%、吟、^1*叶.吩、%、%、叶、#T^*7^*7^"卜吟・"I屯叫.*1、

"S'4'代“4'…、‘“"""*不-i、代*"不不儿心“\n);

printf(M=>请选择你的操作!

\n");

printf(M=>\t\t\tl.显示所有\伦.按姓名查找\n\t\t\t3.按学号查

找\t4.返回主菜单\n“);

scanf(u%dn,&m);

fflush(stdin);

switch(m)

{

casel:

printf("\n=>该系统拥有%(1名学生!

\n\n",head->date.number);

p=head->next;

printf(”\t姓名\t学号\t性别\t数学\t英语\tc语言\t

综合\n\F);

while(p)

pnntf(,At%s\t%d\t%s\t%d\t%d\t%d\t%d\n\p-

>date.name,p->date.number,p->date.sex,p->date.math,

p->date.eglish,p->date.clanguge,p-

>date.average);

p=p->next;

1

break;

case2:

printf("=>请输入查找姓名!

\n°);

gets(N);

fflush(stdin);

p=head->next;

while(p)

{

if(strcmp(p->date.name,N)==O)

{

printfC*\t姓名\t学号\t性别\t数学\t英语\tc语言\t

综合\n”);

printf(H\t%s\t%d\t%s\t%d\t%d\t%d\t%d\nu,p-

>date.name,p->date.number,p->date.sex,p->date.math,

p->date.eglish,p->date.clanguge,p-

>date.average);

水欧阳光明*创编2021.03.07

break;

else

{

p=p->next;

if(p==NULL)

printf(**=>你要查的学生不存在!

”);

1

}

break;

case3:

printf("=>请输入查找学号!

\n");

scanf("%d",&m);

fflush(stdin);

p=head->next;

while(p)

{

if(p->date.number==m)

{

printfC'\t姓名\t学号\t性别\t数学\t英语\tc语言\t

综合\n”);

printf(,,\t%s\t%d\t%s\t%d\t%d\t%d\t%d\n,,,p-

>date.name,p->date.number,p->date.sex,p->date.math,

p->date.eglish,p->date.clanguge,p-

*欧阳光明*创编2021.03.07

>date.average);

break;

else

{

p=p->next;

if(p==NULL)

printf(”=>你要查的学生不存在!

\n”);

}

1

break;

case4:

n=l;break;

return1;

intrange(unit*head)//排序

{

unit*p=head,*q=head->next;

intn,i,m=head->date.number;

•▲亡fft•卜•土•丄"•尢•士•土

*#•>叫、・叶."卜rT%#T%ZTv#T%叶."卜#T%rT%

printfC'\t\t\t1.按学号\t2.按成绩\n\n“);

水欧阳光明*创编

*欧阳光明*创编

printf("=>请选择操作!

\n》”);

scanf("%d",&n);

fflush(stdin);

if(q==NULL)

{printf("=>无学生可排序!

\n”);

return0;

switch(n)

{

case2:

for(i=0;i

{

p=head;q=head->next;

while(q->next)

{

if((q・>date.average)<(q->next->date.average))

{

p->next=q->next;p=p->next;

q->next=p->next;

p->next=q;

1

else

p=p->next;q=q->next;

break;

case1:

for(i=0;iv二m;i++)〃按学号排序

{

p=head;q=head->next;

while(q->next)

{

if((q->date.number)>(q->next->date.number))

p->next=q->next;p=p->next;

q->next=p->next;

p->next=q;

p=p->next;q=q->next;

break;

printf(M=>排序成功!

\n“);

return1;

voidmenu()

■▲亡fVI\•土•尢

tAVIriTT(个个个补金于于个个介个金介于于个介个金怜于个个个个个介金平于个于个

主菜单

printf(H\t\t\tl.新建系统\t2.添加学生\n\t\t\t3.删除学生\t4.查看信息\n\t\W5.排列顺序\t6.读取信息\n\t\t\t7.保存信息\恪.退出系统\n”);printf(M=>请选择你的操作!

\n");

intsave(unit木head)//保存

FILE*fp;

unit*p;

p=head;

if((fp二fopen(“d:

\\学生”,”wb+”))=NULL)

{

printfC'=>保存失败!

“);

return0;

while(p)

{fwrite(&(p->date),sizeof(student),1,fp);

p=p->next;

printf(H=>保存成功!

”);

fclose(fp);

return1;

1

unit*read()〃读入系统学生信息

{

inti;

unit*p,*q,*head;

FILE*fp;

if((head=(unit*)malloc(sizeof(unit)))==NULL)

{printf(n=>开辟空间失败!

”);

exit(l);

else

{

head->next=NULL;

head->date.number=O;//头结点存放学生人数}

q=head;

if((fp二fopen「d:

\\学生TrbJ)二二NULL)

{printf("=>系统无学生!

\n");

return0;

fread(&(q・>date),sizeof(student)」,fp);

for(i=0;idate.number;i++)

{

if((p=(unit*)malloc(sizeof(unit)))==NULL)

{printfC*=>读值失收!

“);

exit(l);

fread(&(p・>date),sizeof(student),1,fp);

p->next=q->next;

q->next=p;

1

fclose(fp);

returnhead;

voidmain()

{

intm=0,n,i;

unit*head;

亡f9I•卜■士■尢%L*%tx*1*%i*%V*1#•"J"*1^%V%1**1*•土•"*1#%L*%V•土%L*%!

W*"卜叫.^7>^T\^v>^T%叶."卜叶.#T%ZT^叶、叶.#vvrT%叶、^7^"卜^7%^T*叶.

);

printf(n\t\t\t*欢迎使用学生成绩管理系统*\n");printf(n\n\t\t\t\t\t\t\t\t^译员:

吹吹风\n\n”);printfC*=>正在读取系统信息……\n“);

if((head=read())==0)

printf(M=>是否新建?

\nu);printf("\t\t\t是

(1)\t\t否

(2)\nH);

scanf(H%dH,&i);

fflush(stdin);

if(i==l)

head=build();

elseif(i==2)

exit(l);

printfC'=>信息导入成功!

”);

while(m==0)

{

menu();

scanf(M%dn,&n);

fflush(stdin);

*欧阳光明*创编

switch(n)case1:

head=build();break;

case2:

add(head);break;

case3:

deletion(head);break;

case4:

display(head);break;

case5:

range(head);break;

case6:

head=read();if(head!

=0)printf('=>读取存盘成功!

\n");break;

case7:

save(head);break;

case8:

m=l;break;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 数学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1