学生成绩管理系统C语言教程文件.docx

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

学生成绩管理系统C语言教程文件.docx

《学生成绩管理系统C语言教程文件.docx》由会员分享,可在线阅读,更多相关《学生成绩管理系统C语言教程文件.docx(21页珍藏版)》请在冰点文库上搜索。

学生成绩管理系统C语言教程文件.docx

学生成绩管理系统C语言教程文件

C语言

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

作者:

学号:

班级:

C语言课程设计

 

题目:

学生成绩管理系统

班级:

2007级计算机应用(4)班

姓名:

学号:

指导教师

完成时间:

2011年1月1日

一、设计目的

进一步加深、巩固学生所学专业课程(《C语言》)的基本理论知识,理论联系实际,进一步培养学生综合分析问题和解决问题的能力。

掌握运用C语言独立地编写、调试应用程序和进行其它相关设计的技能,充分发挥广大同学的潜力,使他们通过本次课程设计而得到全面的锻炼。

二、系统分析

随着科学技术的不断发展,对人们的工作水平要求也越来越高,然而计算机就成了帮助人们解决这个问题的工具,熟练的运用计算机,它能为人们解决许多工作上的难题。

对与一个管理人员来说,快而迅速的了解各种信息是很关键的。

使用计算机在C语言环境下编写相关的管理系统就能达到对相关信息的录入、显示;对记录的查询极其修改等目的。

同时,这个系统与*-*管理系统都有相似之处。

基于同样的C语言环境,对其提供的头文件*h(stdio.h,stdlib.h,string.h,malloc.h,mem.h,ctype.h,conio.h等)的不同组合,能为我们解决许许多多的问题,因此,用它来编写成绩管理管理系统是可行的。

三、成绩管理系统主要功能

1.输入记录

2.用指定格式显示全部记录

3.根据姓名查找记录

4.根据姓名删除记录

5.保存记录到文件

6.按序号显示记录

7.按姓名由小到大的顺序排序

四、系统框图

五、系统流程图

 

六、界面设计

此系统界面采用图形和数字化菜单设计。

主界面设计如下:

*********************************************************

欢迎进入

学生成绩管理系统

制作者:

潍坊科技学院07级计算机应用(4)班杨坤

************************MENU**********************

1.输入学生成绩记录

2.显示学生成绩

3.排序

4.删除记录

5.按姓名查询成绩

6.插入记录

7.保存

8.读取

9.退出

六、用到的头文件及自定义的函数

1、头文件

#include

#include

#include/*其它说明*/

#include/*字符串函数*/

#include/*内存操作函数*/

#include/*字符操作函数*/

#include/*动态地址分配函数*/

2、自定义的功能函数

TUDENT*init();/*初始化函数*/

intmenu_select();/*菜单函数*/

STUDENT*create();/*创建链表*/

voidprint(STUDENT*head);/*显示全部记录函数*/

voidsearch(STUDENT*head);/*查找记录函数*/

STUDENT*delete(STUDENT*head);/*删除记录函数*/

STUDENT*sort(STUDENT*head);/*排序函数*/

STUDENT*insert(STUDENT*head,STUDENT*new);/*插入记录函数*/

voidsave(STUDENT*head);/*保存文件函数*/

STUDENT*load();/*读文件函数*/

有关函数的具体定义以及用法此处不再啰嗦,参看下面的程序代码。

 

七、程序代码

#include

#include

#include/*其它说明*/

#include/*字符串函数*/

#include/*内存操作函数*/

#include/*字符操作函数*/

#include/*动态地址分配函数*/

#defineLENsizeof(STUDENT)

typedefstructstu/*定义结构体数组用于缓存数据*/

{charnum[6];

charname[10];

intscore[3];

intsum;

floataverage;

intorder;

structstu*next;/*链表*/

}STUDENT;

/*函数原型*/

STUDENT*init();/*初始化函数*/

intmenu_select();/*菜单函数*/

STUDENT*create();/*创建链表*/

voidprint(STUDENT*head);/*显示全部记录函数*/

voidsearch(STUDENT*head);/*查找记录函数*/

STUDENT*delete(STUDENT*head);/*删除记录函数*/

STUDENT*sort(STUDENT*head);/*排序函数*/

STUDENT*insert(STUDENT*head,STUDENT*new);/*插入记录函数*/

voidsave(STUDENT*head);/*保存文件函数*/

STUDENT*load();/*读文件函数*/

/*主函数界面*/

voidmain()

{STUDENT*head,new;

head=init();/*链表初始化,使head的值为NULL*/

for(;;)/*循环无限次*/

{switch(menu_select())

{

case1:

head=create();break;/*创建*/

case2:

print(head);break;/*显示*/

case3:

head=sort(head);break;/*排序*/

case4:

head=delete(head);break;/*删除*/

case5:

search(head);break;/*查找*/case6:

head=insert(head,&new);break;/*&new表示返回地址*/

case7:

save(head);break;/*保存*/

case8:

head=load();break;/*读取*/

case9:

exit(0);/*如菜单返回值为9则程序结束*/

}

}

}

/*初始化函数*/

STUDENT*init()

{

returnNULL;/*返回空指针*/

}

/*菜单选择函数*/

menu_select()

{intn;

structdated;/*定义时间结构体*/

getdate(&d);/*读取系统日期并把它放到结构体d中*/

printf("按任意键进入主菜单");/*按任意键进入主菜单*/

getch();/*从键盘读取一个字符,但不显示于屏幕*/

clrscr();/*清屏*/

printf("********************************************************************************\n");

printf("\t\t欢迎进入\n");

printf("\n\t\t学生成绩管理系统\n");

printf("\n\t制作者:

潍坊科技学院07级计算机应用(4)班杨坤\n");

printf("*************************************MENU***************************************\n");

printf("\t\t\t1.输入学生成绩记录\n");

printf("\t\t\t2.显示学生成绩\n");

printf("\t\t\t3.排序\n");

printf("\t\t\t4.删除记录\n");

printf("\t\t\t5.按姓名查询成绩\n");

printf("\t\t\t6.插入记录\n");

printf("\t\t\t7.保存\n");

printf("\t\t\t8.读取\n");

printf("\t\t\t9.退出\n");

printf("********************************************************************************\n");

printf("\t\t\t\t%d\\%d\\%d\n",d.da_year,d.da_mon,d.da_day);/*显示当前系统日期*/

do{

printf("\n\t\t\t请选择项目(1~9):

");

scanf("%d",&n);

}while(n<1||n>9);/*如果选择项不在1~9之间则重输*/

return(n);/*返回选择项,主函数根据该数调用相应的函数*/

}

/*输入函数*/

STUDENT*create()

{inti,s;

STUDENT*head=NULL,*p;/*定义函数.此函数带回一个指向链表头的指针*/

clrscr();

for(;;)

{p=(STUDENT*)malloc(LEN);/*开辟一个新的单元*/

if(!

p)/*如果指针p为空*/

{printf("\n内存已满!

");/*输出内存溢出*/

return(head);/*返回头指针,下同*/

}

printf("输入学号(按'*'输入结束):

");

scanf("%s",p->num);

if(p->num[0]=='*')break;/*如果学号首字符为0则结束输入*/

printf("输入姓名:

");

scanf("%s",p->name);

printf("请输入成绩\n");/*提示开始输入成绩*/

s=0;/*计算每个学生的总分,初值为0*/

for(i=0;i<3;i++)/*3门课程循环3次*/

{

do{

printf("成绩%d:

",i+1);

scanf("%d",&p->score[i]);

if(p->score[i]<0||p->score[i]>100)/*确保成绩在0~100之间*/

printf("请输入0~100之间的数\n");

}while(p->score[i]<0||p->score[i]>100);

s=s+p->score[i];/*累加各门成绩*/

}

p->sum=s;/*将总分保存*/

p->average=(float)s/3;/*先用强制类型转换将s转换成float型,再求平均值*/

p->order=0;/*未排序前此值为0*/

p->next=head;/*将头结点做为新输入结点的后继结点*/

head=p;/*新输入结点为新的头结点*/

}

return(head);

}

/*显示全部记录函数*/

voidprint(STUDENT*head)

{inti=0;/*统计记录条数*/

STUDENT*p;/*移动指针*/

clrscr();

p=head;/*初值为头指针*/

printf("\n**********************************学生成绩表**********************************\n");

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

printf("|记录号|学号|姓名|语文|英语|高数|总分|平均分|排名|\n");

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

while(p!

=NULL)

{

i++;

printf("|%d|%s|%s|%d|%d|%d|%d|%f|%d|\n",

i,p->num,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);

p=p->next;

}

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

printf("**************************************结束**************************************\n");

}

/*排序函数*/

STUDENT*sort(STUDENT*head)

{inti=0;/*保存名次*/

STUDENT*p1,*p2,*t,*temp;/*定义临时指针*/

temp=head->next;/*将原表的头指针所指的下一个结点作头指针*/

head->next=NULL;/*第一个结点为新表的头结点*/

while(temp!

=NULL)/*当原表不为空时,进行排序*/

{

t=temp;/*取原表的头结点*/

temp=temp->next;/*原表头结点指针后移*/

p1=head;/*设定移动指针p1,从头指针开始*/

p2=head;/*设定移动指针p2做为p1的前驱,初值为头指针*/

while(t->averageaverage&&p1!

=NULL)/*作成绩平均分比较*/

{

p2=p1;/*待排序点值小,则新表指针后移*/

p1=p1->next;

}

if(p1==p2)/*p1==p2,说明待排序点值大,应排在首位*/

{

t->next=p1;/*待排序点的后继为p*/

head=t;/*新头结点为待排序点*/

}

else/*待排序点应插入在中间某个位置p2和p1之间,如p为空则是尾部*/

{

t->next=p1;/*t的后继是p1*/

p2->next=t;/*p2的后继是t*/

}

}

p1=head;/*已排好序的头指针赋给p1,准备填写名次*/

while(p1!

=NULL)/*当p1不为空时,进行下列操作*/

{

i++;/*结点序号*/

p1->order=i;/*将结点序号赋值给名次*/

p1=p1->next;/*指针后移*/

}

printf("排序成功\n");/*排序成功*/

return(head);

}

/*删除记录函数*/

STUDENT*delete(STUDENT*head)

{intn=0;

STUDENT*p1,*p2;/*p1为查找到要删除的结点指针,p2为其前驱指针*/

charc,s[6];/*s[6]用来存放学号,c用来输入字母*/

clrscr();

printf("请输入要删除的学生的学号:

");

scanf("%s",s);

p1=p2=head;/*给p1和p2赋初值头指针*/

while(strcmp(p1->num,s)&&p1!

=NULL)/*当记录的学号不是要找的,或指针不为空时*/

{p2=p1;/*将p1指针值赋给p2作为p1的前驱指针*/

p1=p1->next;/*将p1指针指向下一条记录*/

}

if(strcmp(p1->num,s)==0)/*学号找到了*/

{printf("**************************************信息如下************************************\n");

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

printf("|学号|姓名|语文|英语|高数|总分|平均分|排名|\n");

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

printf("|%s|%s|%d|%d|%d|%d|%f|%d|\n",

p1->num,p1->name,p1->score[0],p1->score[1],p1->score[2],p1->sum,p1->average,p1->order);

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

printf("***************************************结束**************************************\n");

printf("确定要删除吗?

Y/N?

");/*提示是否要删除,输入Y删除,N则退出*/

for(;;)

{scanf("%c",&c);

if(c=='n'||c=='N')break;/*如果不删除,则跳出本循环*/

if(c=='y'||c=='Y')

{

if(p1==head)/*若p1==head,说明被删结点是首结点*/

head=p1->next;/*把第二个结点地址赋予head*/

else

p2->next=p1->next;/*否则将一下结点地址赋给前一结点地址*/

n=n-1;

printf("\n学号%s已删除\n",s);

printf("请保存\n");break;/*删除后就跳出循环*/

}

}

}

else

printf("\n没有找到该生\n");/*找不到该结点*/

return(head);

}

/*查找记录函数*/

voidsearch(STUDENT*head)

{STUDENT*p;/*移动指针*/

chars[5];/*存放姓名用的字符数组*/

clrscr();

printf("请输入要查找的姓名\n");

scanf("%s",s);

p=head;/*将头指针赋给p*/

while(strcmp(p->name,s)&&p!

=NULL)/*当记录的姓名不是要找的,或指针不为空时*/

p=p->next;/*移动指针,指向下一结点*/

if(p!

=NULL)/*如果指针不为空*/

{printf("\n*************************************查找************************************\n");

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

printf("|学号|姓名|语文|英语|高数|总分|平均分|排名|\n");

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

printf("|%s|%s|%d|%d|%d|%d|%f|%d|\n",

p->num,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);

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

printf("***************************************结束**************************************\n");

}

else

printf("\n没有该学生\n");/*显示没有该学生*/

}

 

/*插入记录函数*/

STUDENT*insert(STUDENT*head,STUDENT*new)

{STUDENT*p0,*p1,*p2;

intn=0,sum1,i;

p1=head;/*使p1指向第一个结点*/

p0=new;/*p0指向要插入的结点*/

printf("\n请输入一个新记录\n");/*提示输入记录信息*/

printf("输入学号:

");

scanf("%s",new->num);

printf("输入姓名:

");

scanf("%s",new->name);

printf("请输入成绩\n");

sum1=0;/*保存新记录的总分,初值为0*/

for(i=0;i<3;i++)

{

do{

printf("成绩%d:

",i+1);

scanf("%d",&new->score[i]);

if(new->score[i]>100||new->score[i]<0)

printf("请输入0~100之间的数\n");

}while(new->score[i]>100||new->score[i]<0);

sum1=sum1+new->score[i];/*累加各门成绩*/

}

new->sum=sum1;/*将总分存入新记录中*/

new->average=(float)sum1/3;

new->order=0;

if(head==NULL)/*原来的链表是空表*/

{head=p0;p0->next=NULL;}/*使p0指向的结点作为头结点*/

else

{while((p0->averageaverage)&&(p1->next!

=NULL))

{p2=p1;/*使p2指向刚才p1指向的结点*/

p1=p1->next;/*p1后移一个结点*/

}

if(p0->average>=p1->average)

{if(head==p1)head=p0;/*插到原来第一个结点之前*/

elsep2->next=p0;/*插到p2指向的结点之后*/

p0->next=p1;}

else

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

当前位置:首页 > 医药卫生 > 基础医学

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

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