学生成绩管理系统C程序设计Word格式文档下载.docx

上传人:b****1 文档编号:4232798 上传时间:2023-05-03 格式:DOCX 页数:17 大小:50.27KB
下载 相关 举报
学生成绩管理系统C程序设计Word格式文档下载.docx_第1页
第1页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第2页
第2页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第3页
第3页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第4页
第4页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第5页
第5页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第6页
第6页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第7页
第7页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第8页
第8页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第9页
第9页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第10页
第10页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第11页
第11页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第12页
第12页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第13页
第13页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第14页
第14页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第15页
第15页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第16页
第16页 / 共17页
学生成绩管理系统C程序设计Word格式文档下载.docx_第17页
第17页 / 共17页
亲,该文档总共17页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

学生成绩管理系统C程序设计Word格式文档下载.docx

《学生成绩管理系统C程序设计Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《学生成绩管理系统C程序设计Word格式文档下载.docx(17页珍藏版)》请在冰点文库上搜索。

学生成绩管理系统C程序设计Word格式文档下载.docx

%s"

p->

data.name);

getchar();

请你输入性别:

data.sex);

图1.6保存文件与退出系统

3、重要函数介绍

数据输入函数“cin()” 

查看数据函数“lookdata()” 

 

插入数据的函数“insert()”

查看数据的函数“find()”

更新数据的函数“update()” 

保留数据函数“save()”

主函数main()

学过的知识理解得不够深刻,掌握得不够牢固,比如说结构体,指针,链表……通过这次课程设计之后,我们把前面所学过的知识又重新温故了一遍。

我做的是学生成绩管理系统,虽然是很简单的一个小的程序,但对我一个初学者来说却是一个很大的困难。

更加是第一次做课程设计,所以连续做了几天却丝毫没有进展,最主要是不知从何开始,这个时候才知道上课老师们不厌其烦的教导是多么的宝贵,这个时候才后悔上课的时候没有认真的听讲。

可是现在一切都晚了,还好时间还算是充裕,只好拿出书本重新复习一下。

特别是结构体,指针的部分,几乎是一片空白。

不过经过几天的努力,大体上把课本上的知识点看了一遍,知识点也都基本是撑握了,所以一下一步就是开始正式的编程序了。

不过毕竟是个新手,还是不知如何下手,于是就在网上下了一篇类似的程序,经过仔细的研究,终于读懂了C语言编程的基本过程和方法。

经过一波三折,终于intcgrade;

intmgrade;

integrade;

inttotle;

intave;

charneartime[10];

/*最近更新时间*/

};

typedefstructnode

{

structstudentdata;

structnode*next;

}Node,*Link;

voidmenu()

********************************************************************************"

\t1登记学生资料\t\t\t\t\t2删除学生资料\n"

\t3查询学生资料\t\t\t\t\t4修改学生资料\n"

\t5保存学生资料\t\t\t\t\t0退出系统\n"

********************************************************************************\n"

voidprintstart()

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

voidWrong()

\n=====>

提示:

输入错误!

voidNofind()

没有找到该学生!

voidprintc()/*本函数用于输出中文*/

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

voidprinte(Node*p)/*本函数用于输出英文*/

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

data.num,p->

data.name,p->

data.sex,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->

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;

charnum[10];

r=l;

s=l->

while(r->

next!

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

while

(1)

请你输入学号(以'

0'

返回上一级菜单:

)"

num);

if(strcmp(num,"

0"

)==0)

break;

while(s)

if(strcmp(s->

data.num,num)==0)

=====>

学号为'

%s'

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

4修改'

!

请你输入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):

请你输入新的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;

\t\t\t\t学生成绩管理系统\n\t\t\t\t-------湖南文理学院自动化07101(30号)\n"

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:

/*保存学生*/

case9:

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

default:

Wrong();

/**/

七、调试结果

学生资料的登记

学生资料的查找

学生资料的修改

学生资料的删除

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

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

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2