学生成绩管理系统课程设计报告.docx

上传人:b****0 文档编号:9858193 上传时间:2023-05-21 格式:DOCX 页数:43 大小:697.07KB
下载 相关 举报
学生成绩管理系统课程设计报告.docx_第1页
第1页 / 共43页
学生成绩管理系统课程设计报告.docx_第2页
第2页 / 共43页
学生成绩管理系统课程设计报告.docx_第3页
第3页 / 共43页
学生成绩管理系统课程设计报告.docx_第4页
第4页 / 共43页
学生成绩管理系统课程设计报告.docx_第5页
第5页 / 共43页
学生成绩管理系统课程设计报告.docx_第6页
第6页 / 共43页
学生成绩管理系统课程设计报告.docx_第7页
第7页 / 共43页
学生成绩管理系统课程设计报告.docx_第8页
第8页 / 共43页
学生成绩管理系统课程设计报告.docx_第9页
第9页 / 共43页
学生成绩管理系统课程设计报告.docx_第10页
第10页 / 共43页
学生成绩管理系统课程设计报告.docx_第11页
第11页 / 共43页
学生成绩管理系统课程设计报告.docx_第12页
第12页 / 共43页
学生成绩管理系统课程设计报告.docx_第13页
第13页 / 共43页
学生成绩管理系统课程设计报告.docx_第14页
第14页 / 共43页
学生成绩管理系统课程设计报告.docx_第15页
第15页 / 共43页
学生成绩管理系统课程设计报告.docx_第16页
第16页 / 共43页
学生成绩管理系统课程设计报告.docx_第17页
第17页 / 共43页
学生成绩管理系统课程设计报告.docx_第18页
第18页 / 共43页
学生成绩管理系统课程设计报告.docx_第19页
第19页 / 共43页
学生成绩管理系统课程设计报告.docx_第20页
第20页 / 共43页
亲,该文档总共43页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

学生成绩管理系统课程设计报告.docx

《学生成绩管理系统课程设计报告.docx》由会员分享,可在线阅读,更多相关《学生成绩管理系统课程设计报告.docx(43页珍藏版)》请在冰点文库上搜索。

学生成绩管理系统课程设计报告.docx

学生成绩管理系统课程设计报告

 

C语言课程设计报告

 

题目:

学生成绩管理系统

设计者:

张亚鹏

专业班级:

通信工程0901

学号:

310909020127

指导教师:

张黎娜

 

2010年09月15日

河南理工大学计算机学院

 

 

成绩管理系统

1题目与要求

1.1问题提出

本人计划编写一个学生成绩管理系统,主要用来管理学生成绩信息。

1.2本系统涉及的知识点

结构、数组、循环、函数、分支、指针。

1.3功能要求

主要功能:

(1)能完成对学生成绩的录入、修改;

(2)能统计学生的成绩,求学生的总分及平均分,并能根据学生的平均成绩进行排序;

(3)能查询学生成绩,不及格科目及学生名单;

(4)能输出学生的成绩单。

2功能设计

2.1算法设计

利用switch语句设计如图1所示的主菜单:

请输入选项编号(0~9)

0——退出系统

1——输入学生资料

2——查询学生成绩

3——删除学生资料

4——追加学生资料

5——显示学生成绩

6——统计学生成绩

7——对成绩进行排序

图1学生信息管理系统主菜单

(所有的图统一编号,宋体5号,置于图下的中间,)

排序菜单

请输入选项编号(0~5)

1—按学号排序

2—按姓名排序

3—按语文成绩排序

4—按英语成绩排序

5—按数学成绩排序

选择9后,调用排序函数,进入函数后利用switch语句实现一个如图2所示的菜单,该菜单中每个选项调用一个函数。

 

 

图2排序子菜单

 

3主要技术指标及特点

图3程序模块

3.1登录界面显示

图4

口令输入正确后,主菜单将显示及可以进行操作。

图5

此登录界面是预先设定好作为菜单来显示的,在主函数中以menu2311()来实现的,在函数中,是通过switch……case来实现选择功能的,用户可以通过需要进行选择,方便了用户的使用,非常人性化。

请输入选项编号(0~9)

0——退出系统

1——输入学生资料

2——从文件调入资料

3——查询学生成绩

4——删除学生资料

5——追加学生资料

6——显示学生成绩

排序菜单

请输入选项编号(0~5)

1—按学号排序

2—按姓名排序

3—按语文成绩排序

4—按英语成绩排序

5—按数学成绩排序

7——统计学生成绩

8——保存输入的资料

9——对成绩进行排序

图6图7

选择9后,调用排序函数,进入函数后利用switch语句实现一个如图7所示的菜单,该菜单中每个选项调用一个函数

3.2输入学生资料

图8

3.3删除学生资料

图9

这里又是通过switch……case函数的调用,让用户进行选择,共有两种方法:

1.按照学号2.按照姓名,操作完成后,系统会自动提示,该学生已经成功删除,当再次显示的时候,函数中的链表就不再指向该学号,从而起到删除的作用。

删除完成后,再次保存一下学生资料,不然系统仍然默认为原始人数。

3.4追加学生资料

图10

通过选择到达修改界面:

此时将呈现出现有的学生资料,按照要求将新的信息输入其中,再保存资料,如果输入的学号系统中未显示,那么系统则提示没有资料可以修改。

3.5查询学生资料

图11

按照选择,则会呈现出用户需要查找的所有信息,每次呈现出来的时候都要用之前定义的print2311()函数,这个很好地将数据按照格式化的形式显现出来。

此为按照学号查找的例子,按照姓名查找是同样道理。

3.6统计学生资料(自加功能)

图12

图13

统计学生资料主要还是用的statistics2311()函数。

3.7对学生成绩进行排序

图14

图15

该图显示的是按照语文成绩排序完的结果,用链表将数据进行一个接一个的比较,按照降序将学生信息排列下来,最后提示排序已经完成,并将所有结果按照用户要求显示出来。

3.8程序主要代码

#include

#include

#defineLENsizeof(structscorenode)

#defineDEBUG

#include

structscorenode

{

intnumber;/*学号*/

charname[10];/*姓名*/

floatyuwen;/*语文成绩*/

floatyingyu;/*英语成绩*/

floatshuxue;/*数学成绩*/

structscorenode*next;

};

typedefstructscorenodescore;

intm,n,k,jj;/*n,k为全局变量,本程序中的函数均可以使用它*/

score*creat2311(void)/*函数creat2311,功能:

创建链表,此函数带回一个指向链表头的指针*/

{

score*head;

score*p1,*p2,*p3,*max;

inti,j;

floatfen;

chart[10];

n=0;

p1=p2=p3=(score*)malloc(LEN);head=p3;/*开辟一个新单元*/

printf("请输入学生资料,输0退出!

\n");

repeat1:

printf("请输入学生学号(学号应大于0):

");/*输入学号,学号应大于0*/

scanf("%d",&p1->number);

while(p1->number<0)

{

getchar();

printf("输入错误,请重新输入学生学号:

");

scanf("%d",&p1->number);

}/*输入学号为字符或小于0时,程序报错,提示重新输入学号*/

if(p1->number==0)

gotoend;/*当输入的学号为0时,转到末尾,结束创建链表*/

else

{

p3=head;

if(n>0)

{

for(i=0;i

{

if(p1->number!

=p3->number)

p3=p3->next;

else

{

printf("学号重复,请重输!

\n");

gotorepeat1;/*当输入的学号已经存在,程序报错,返回前面重新输入*/

}

}

}

}

printf("请输入学生姓名:

");

scanf("%s",&p1->name);/*输入学生姓名*/

printf("请输入语文成绩(0~100):

");/*输入语文成绩,成绩应在0-100*/

scanf("%f",&p1->yuwen);

while(p1->yuwen<0||p1->yuwen>100)

{

getchar();

printf("输入错误,请重新输入语文成绩");/*输入错误,重新输入语文成绩直到正确为止*/

scanf("%f",&p1->yuwen);

}

printf("请输入英语成绩(0~100):

");/*输入英语成绩,绩应在0-100*/

scanf("%f",&p1->yingyu);

while(p1->yingyu<0||p1->yingyu>100)

{

getchar();

printf("输入错误,请重新输入英语成绩");/*输入错误,重新输入英语成绩直到正确为止*/

scanf("%f",&p1->yingyu);

}

printf("请输入数学成绩(0~100):

");/*输入数学成绩,成绩应在0-100*/

scanf("%f",&p1->shuxue);

while(p1->shuxue<0||p1->shuxue>100)

{

getchar();

printf("输入错误,请重新输入数学成绩");

scanf("%f",&p1->shuxue);

}/*输入错误,重新输入数学成绩直到正确为止*/

head=NULL;

while(p1->number!

=0)

{

n=n+1;

if(n==1)

head=p1;

else

p2->next=p1;

p2=p1;

p1=(score*)malloc(LEN);

printf("请输入学生资料,输0退出!

\n");

repeat2:

printf("请输入学生学号(学号应大于0):

");

scanf("%d",&p1->number);/*输入学号,学号应大于0*/

while(p1->number<0)

{

getchar();

printf("输入错误,请重新输入学生学号:

");

scanf("%d",&p1->number);

}/*输入学号为字符或小于0时,程序报错,提示重新输入学号*/

if(p1->number==0)

gotoend;/*当输入的学号为0时,转到末尾,结束创建链表*/

else

{

p3=head;

if(n>0)

{

for(i=0;i

{

if(p1->number!

=p3->number)

p3=p3->next;

else

{

printf("学号重复,请重输!

\n");

gotorepeat2;/*当输入的学号已经存在,程序报错,返回前面重新输入*/

}

}

}

}

printf("请输入学生姓名:

");

scanf("%s",&p1->name);/*输入学生姓名*/

printf("请输入语文成绩(0~100):

");

scanf("%f",&p1->yuwen);/*输入语文成绩,成绩应在0-100*/

while(p1->yuwen<0||p1->yuwen>100)

{

getchar();

printf("输入错误,请重新输入语文成绩");

scanf("%f",&p1->yuwen);

}/*输入错误,重新输入语文成绩直到正确为止*/

printf("请输入英语成绩(0~100):

");

scanf("%f",&p1->yingyu);/*输入英语成绩,成绩应在0-100*/

while(p1->yingyu<0||p1->yingyu>100)

{

getchar();

printf("输入错误,请重新输入英语成绩");

scanf("%f",&p1->yingyu);

}/*输入错误,重新输入英语成绩直到正确为止*/

printf("请输入数学成绩(0~100):

");

scanf("%f",&p1->shuxue);/*输入数学成绩,成绩应在0-100*/

while(p1->shuxue<0||p1->shuxue>100)

{

getchar();

printf("输入错误,请重新输入数学成绩");

scanf("%f",&p1->shuxue);

}/*输入错误,重新输入数学成绩直到正确为止*/

}

end:

p1=head;

p3=p1;

for(i=1;i

{

for(j=i+1;j<=n;j++)

{

max=p1;

p1=p1->next;

if(max->number>p1->number)

{

k=max->number;

max->number=p1->number;

p1->number=k;/*交换前后结点中的学号值,使得学号大者移到后面的结点中*/

strcpy(t,max->name);

strcpy(max->name,p1->name);

strcpy(p1->name,t);/*交换前后结点中的姓名,使之与学号相匹配*/

fen=max->yuwen;

max->yuwen=p1->yuwen;

p1->yuwen=fen;/*交换前后结点中的语文成绩,使之与学号相匹配*/

fen=max->yingyu;

max->yingyu=p1->yingyu;

p1->yingyu=fen;/*交换前后结点中的英语成绩,使之与学号相匹配*/

fen=max->shuxue;

max->shuxue=p1->shuxue;

p1->shuxue=fen;/*交换前后结点中的数学成绩,使之与学号相匹配*/

}

}

max=head;p1=head;/*重新使max,p指向链表头*/

}

p2->next=NULL;/*链表结尾*/

printf("输入的学生数为:

%d个!

\n",n);

return(head);

}

/*==============================================================================================*/

/*==============================================================================================*/

score*add2311(score*head,score*stu)/*函数add2311,功能:

追加学生资料,并且将所有学生资料按学号排序*/

{

score*p0,*p1,*p2,*p3,*max;

inti,j;

floatfen;

chart[10];

p3=stu=(score*)malloc(LEN);/*开辟一个新单元*/

printf("\n输入要增加的学生的资料!

");

repeat4:

printf("请输入学生学号(学号应大于0):

");

scanf("%d",&stu->number);/*输入学号,学号应大于0*/

while(stu->number<0)

{

getchar();

printf("输入错误,请重新输入学生学号:

");

scanf("%d",&stu->number);}/*输入错误,重新输入学号*/

/******************************************************/

if(stu->number==0)

gotoend2;/*当输入的学号为0时,转到末尾,结束追加*/

else

{

p3=head;

if(n>0)

{

for(i=0;i

{

if(stu->number!

=p3->number)

p3=p3->next;

else

{

printf("学号重复,请重输!

\n");

gotorepeat4;/*当输入的学号已经存在,程序报错,返回前面重新输入*/

}

}

}

}

/******************************************************/

printf("输入学生姓名:

");

scanf("%s",stu->name);/*输入学生姓名*/

printf("请输入语文成绩(0~100):

");

scanf("%f",&stu->yuwen);/*输入语文成绩,成绩应在0-100*/

while(stu->yuwen<0||stu->yuwen>100)

{

getchar();

printf("输入错误,请重新输入语文成绩");

scanf("%f",&stu->yuwen);}/*输入错误,重新输入语文成绩直到正确为止*/

printf("请输入英语成绩(0~100):

");

scanf("%f",&stu->yingyu);/*输入英语成绩,成绩应在0-100*/

while(stu->yingyu<0||stu->yingyu>100)

{

getchar();

printf("输入错误,请重新输入英语成绩");

scanf("%f",&stu->yingyu);}/*输入错误,重新输入英语成绩直到正确为止*/

printf("请输入数学成绩(0~100):

");

scanf("%f",&stu->shuxue);/*输入数学成绩,成绩应在0-100*/

while(stu->shuxue<0||stu->shuxue>100)

{

getchar();

printf("输入错误,请重新输入数学成绩");

scanf("%f",&stu->shuxue);}/*输入错误,重新输入数学成绩直到正确为止*/

p1=head;

p0=stu;

if(head==NULL)

{

head=p0;p0->next=NULL;

}/*当原来链表为空时,从首结点开始存放资料*/

else/*原来链表不为空*/

{

if(p1->next==NULL)/*找到原来链表的末尾*/

{

p1->next=p0;

p0->next=NULL;/*将它与新开单元相连接*/

}

else

{

while(p1->next!

=NULL)/*还没找到末尾,继续找*/

{

p2=p1;

p1=p1->next;

}

p1->next=p0;

p0->next=NULL;

}

}

n=n+1;

p1=head;

p0=stu;

for(i=1;i

{

for(j=i+1;j<=n;j++)

{

max=p1;

p1=p1->next;

if(max->number>p1->number)

{

k=max->number;

max->number=p1->number;

p1->number=k;/*交换前后结点中的学号值,使得学号大者移到后面的结点中*/

strcpy(t,max->name);

strcpy(max->name,p1->name);

strcpy(p1->name,t);/*交换前后结点中的姓名,使之与学号相匹配*/

fen=max->yuwen;

max->yuwen=p1->yuwen;

p1->yuwen=fen;/*交换前后结点中的语文成绩,使之与学号相匹配*/

fen=max->yingyu;

max->yingyu=p1->yingyu;

p1->yingyu=fen;/*交换前后结点中的英语成绩,使之与学号相匹配*/

fen=max->shuxue;

max->shuxue=p1->shuxue;

p1->shuxue=fen;/*交换前后结点中的数学成绩,使之与学号相匹配*/

}

}

max=head;p1=head;/*重新使max,p指向链表头*/

}

end2:

printf("现在的学生数为:

%d个!

\n",n);

return(head);

}

/*==============================================================================================*/

/*==============================================================================================*/

score*search2311(score*head)/*函数search2311,功能:

查询学生成绩*/

{

intnumber;

score*p1,*p2;

printf("输入要查询的学生的学号,");

scanf("%d",&number);

while(number!

=0)

{

if(head==NULL)

{

printf("\n没有任何学生资料!

\n");return(head);

}

printf("-----------------------------------------\n");

printf("|学号\t|姓名\t|语文\t|英语\t|数学\t|\n");

printf("-----------------------------------------\n");/*打印表格域*/

p1=head;

while(number!

=p1->number&&p1->next!

=NULL)

{

p2=p1;

p1=p1->next;

}

if(number==p1->number)

{

printf("|%d\t|%s\t|%.1f\t|%.1f\t|%.1f\t|\n",p1->number,p1->name,p1->yuwen,p1->yingyu,p1->shuxue);

printf("-----------------------------------------\n");

}/*打印表格域*/

else

printf("%d不存在此学生!

\n",number);

printf("输入要查询的学生的学号,");

scanf("%d",&number);

}

printf("已经退出了!

\n");

return(head);

}

/*==============================================================================================

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

当前位置:首页 > 小学教育 > 语文

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

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