学生成绩管理Word格式.docx

上传人:b****8 文档编号:22219995 上传时间:2023-02-03 格式:DOCX 页数:20 大小:22.86KB
下载 相关 举报
学生成绩管理Word格式.docx_第1页
第1页 / 共20页
学生成绩管理Word格式.docx_第2页
第2页 / 共20页
学生成绩管理Word格式.docx_第3页
第3页 / 共20页
学生成绩管理Word格式.docx_第4页
第4页 / 共20页
学生成绩管理Word格式.docx_第5页
第5页 / 共20页
点击查看更多>>
下载资源
资源描述

学生成绩管理Word格式.docx

《学生成绩管理Word格式.docx》由会员分享,可在线阅读,更多相关《学生成绩管理Word格式.docx(20页珍藏版)》请在冰豆网上搜索。

学生成绩管理Word格式.docx

stdio.h"

#include"

stdlib.h"

string.h"

intshoudsave=0;

/**/

structstudent

{

charnum[10];

/*学号*/

charname[20];

charsex[4];

charremove[10];

/*班级*/

intcgrade;

intmgrade;

integrade;

inttotle;

intave;

charneartime[10];

};

typedefstructnode

structstudentdata;

structnode*next;

}Node,*Link;

voidmenu()

printf("

统计系统"

);

\t1登记学生资料\n"

\t2删除学生资料\n"

\t3查询学生资料\n"

\t4修改学生资料\n"

\t5保存学生资料\n"

\t6显示学生成绩\n"

\t7统计学生成绩\n"

\t0退出系统\n"

\n"

}

voidprintstart()

-----------------------------------------------------------------------\n"

voidWrong()

\n=====>

提示:

输入错误!

voidNofind()

没有找到该学生!

voidprintc()

学号\t姓名性别班级英语成绩数学成绩C语言成绩总分平均分\n"

voidprinte(Node*p)

%-12s%s\t%s\t%s\t%d\t%d\t%d\t%d\t%d\n"

p->

data.num,p->

data.name,p->

data.sex,p->

data.remove,p->

data.egrade,p->

data.mgrade,p->

data.cgrade,p->

data.totle,p->

data.ave);

Node*Locate(Linkl,charfindmess[],charnameornum[])/*该函数用于定位连表中符合要求的接点,并返回该指针*/

Node*r;

if(strcmp(nameornum,"

num"

)==0)/*按学号查询*/

r=l->

next;

while(r!

=NULL)

if(strcmp(r->

data.num,findmess)==0)

returnr;

r=r->

elseif(strcmp(nameornum,"

name"

)==0)/*按姓名查询*/

data.name,findmess)==0)

return0;

voidAdd(Linkl)/*增加学生*/

Node*p,*r,*s;

r=l;

s=l->

while(r->

next!

/*将指针置于最末尾*/

while

(1)

请你输入学号(以'

0'

返回上一级菜单:

)"

scanf("

%s"

num);

if(strcmp(num,"

0"

)==0)

break;

while(s)

if(strcmp(s->

data.num,num)==0)

=====>

学号为'

%s'

的学生已经存在,若要修改请你选择'

4修改'

!

printstart();

printc();

printe(s);

return;

s=s->

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

strcpy(p->

data.num,num);

请你输入姓名:

"

data.name);

getchar();

请你输入性别:

data.sex);

请你输入班级:

data.remove);

请你输入c语言成绩:

%d"

&

p->

data.cgrade);

请你输入数学成绩:

data.mgrade);

请你输入英语成绩:

data.egrade);

data.totle=p->

data.egrade+p->

data.cgrade+p->

data.mgrade;

data.ave=p->

data.totle/3;

/*信息输入已经完成*/

next=NULL;

r->

next=p;

r=p;

shoudsave=1;

voidQur(Linkl)/*查询学生*/

intsel;

charfindmess[20];

Node*p;

if(!

l->

next)

没有资料可以查询!

1按学号查找\n=====>

2按姓名查找\n"

sel);

if(sel==1)/*学号*/

请你输入要查找的学号:

findmess);

p=Locate(l,findmess,"

if(p)

\t\t\t\t查找结果\n"

printe(p);

else

Nofind();

elseif(sel==2)/*姓名*/

请你输入要查找的姓名:

Wrong();

voidDel(Linkl)/*删除*/

Node*p,*r;

没有资料可以删除!

1按学号删除\n=====>

2按姓名删除\n"

if(sel==1)

请你输入要删除的学号:

=p)

next=p->

free(p);

该学生已经成功删除!

elseif(sel==2)

请你输入要删除的姓名:

voidModify(Linkl)

没有资料可以修改!

请你输入要修改的学生学号:

请你输入新学号(原来是%s):

data.num);

请你输入新姓名(原来是%s):

请你输入新性别(原来是%s):

请你输入新班级(原来是%s):

请你输入新的c语言成绩(原来是%d分):

请你输入新的数学成绩(原来是%d分):

请你输入新的英语成绩(原来是%d分):

data.totle/3;

资料修改成功!

voidDisp(Linkl)

intcount=0;

p=l->

p)

没有资料可以显示!

\t\t\t\t显示结果\n"

while(p)

p=p->

voidTongji(Linkl)

Node*pm,*pe,*pc,*pt,*pa;

/*用于指向分数最高的接点*/

Node*r=l->

r)

没有资料可以统计!

return;

pm=pe=pc=pt=pa=r;

if(r->

data.cgrade>

=pc->

data.cgrade)

pc=r;

data.mgrade>

=pm->

data.mgrade)

pm=r;

data.egrade>

=pe->

data.egrade)

pe=r;

data.totle>

=pt->

data.totle)

pt=r;

data.ave>

=pa->

data.ave)

pa=r;

------------------------------统计结果--------------------------------\n"

总分最高者:

\t%s%d分\n"

pt->

data.name,pt->

data.totle);

平均分最高者:

pa->

data.name,pa->

英语最高者:

pe->

data.name,pe->

数学最高者:

pm->

data.name,pm->

c语言最高者:

pc->

data.name,pc->

voidSort(Linkl)

Linkll;

Node*p,*rr,*s;

ll=(Link)malloc(sizeof(Node));

/*用于做新的连表*/

ll->

if(l->

next==NULL)

没有资料可以排序!

s=(Node*)malloc(sizeof(Node));

/*新建接点用于保存信息*/

s->

data=p->

data;

rr=ll;

while(rr->

=NULL&

&

rr->

next->

=p->

rr=rr->

if(rr->

rr->

next=s;

next=rr->

free(l);

next=ll->

排序已经完成!

voidSave(Linkl)

FILE*fp;

intflag=1,count=0;

fp=fopen("

c:

\\student"

"

wb"

if(fp==NULL)

重新打开文件时发生错误!

exit

(1);

if(fwrite(p,sizeof(Node),1,fp)==1)

count++;

flag=0;

if(flag)

文件保存成功.(有%d条记录已经保存.)\n"

count);

shoudsave=0;

fclose(fp);

voidmain()

Linkl;

/*连表*/

FILE*fp;

/*文件指针*/

charch;

charjian;

l=(Node*)malloc(sizeof(Node));

C:

rb"

文件还不存在,是否创建?

(y/n)\n"

%c"

jian);

if(jian=='

y'

||jian=='

Y'

exit(0);

文件已经打开,正在导入记录......\n"

while(!

feof(fp))

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

if(fread(p,sizeof(Node),1,fp))/*将文件的内容放入接点中*/

/*将该接点挂入连中*/

/*关闭文件*/

记录导入完毕,共导入%d条记录.\n"

menu();

请你选择操作:

if(sel==0)

if(shoudsave==1)

{getchar();

资料已经改动,是否将改动保存到文件中(y/n)?

ch);

if(ch=='

||ch=='

Save(l);

你已经退出系统,再见!

switch(sel)

case1:

Add(l);

/*增加学生*/

case2:

Del(l);

/*删除学生*/

case3:

Qur(l);

/*查询学生*/

case4:

Modify(l);

/*修改学生*/

case5:

/*保存学生*/

case6:

Disp(l);

/*显示成绩*/

case7:

Tongji(l);

/*统计成绩*/

case9:

\t\t\t==========帮助信息==========\n"

default:

Wrong();

/**/

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

当前位置:首页 > 解决方案 > 学习计划

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

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