学生成绩管理系统C语言Word格式.docx

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

学生成绩管理系统C语言Word格式.docx

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

学生成绩管理系统C语言Word格式.docx

stdlib.h>

/*其它说明*/

string.h>

/*字符串函数*/

mem.h>

/*内存操作函数*/

ctype.h>

/*字符操作函数*/

alloc.h>

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

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<

#defineLENsizeof(STUDENT)

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

{charnum[6];

charname[10];

intscore[3];

intsum;

floataverage;

intorder;

structstu*next;

/*链表*/

}STUDENT;

/*函数原型*/

STUDENT*init();

/*主函数界面*/

voidmain()

{STUDENT*head,new;

head=init();

/*链表初始化,使head的值为NULL*/

for(;

;

)/*循环无限次*/

{switch(menu_select())

{

case1:

head=create();

break;

/*创建*/

case2:

print(head);

/*显示*/

case3:

head=sort(head);

/*排序*/

case4:

head=delete(head);

/*删除*/

case5:

search(head);

/*查找*/case6:

head=insert(head,&

new);

/*&

new表示返回地址*/

case7:

save(head);

/*保存*/

case8:

head=load();

break;

/*读取*/

case9:

exit(0);

/*如菜单返回值为9则程序结束*/

}

}

/*初始化函数*/

STUDENT*init()

{

returnNULL;

/*返回空指针*/

/*菜单选择函数*/

menu_select()

{intn;

structdated;

/*定义时间结构体*/

getdate(&

d);

/*读取系统日期并把它放到结构体d中*/

printf("

按任意键进入主菜单"

);

/*按任意键进入主菜单*/

getch();

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

clrscr();

/*清屏*/

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

\t\t欢迎进入\n"

\n\t\t学生成绩管理系统\n"

\n\t制作者:

西北民族大学08级通信工程

(1)班吴欣萌马云向昊瀚程冲冲\n"

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

\t\t\t1.输入学生成绩记录\n"

\t\t\t2.显示学生成绩\n"

\t\t\t3.排序\n"

\t\t\t4.删除记录\n"

\t\t\t5.按姓名查询成绩\n"

\t\t\t6.插入记录\n"

\t\t\t7.保存\n"

\t\t\t8.读取\n"

\t\t\t9.退出\n"

\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;

/*定义函数.此函数带回一个指向链表头的指针*/

{p=(STUDENT*)malloc(LEN);

/*开辟一个新的单元*/

if(!

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

{printf("

\n内存已满!

/*输出内存溢出*/

return(head);

/*返回头指针,下同*/

输入学号(按'

*'

输入结束):

%s"

p->

num);

if(p->

num[0]=='

)break;

/*如果学号首字符为0则结束输入*/

输入姓名:

name);

请输入成绩\n"

/*提示开始输入成绩*/

s=0;

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

for(i=0;

i<

3;

i++)/*3门课程循环3次*/

do{

成绩%d:

i+1);

p->

score[i]);

score[i]<

0||p->

score[i]>

100)/*确保成绩在0~100之间*/

请输入0~100之间的数\n"

}while(p->

100);

s=s+p->

score[i];

/*累加各门成绩*/

p->

sum=s;

/*将总分保存*/

average=(float)s/3;

/*先用强制类型转换将s转换成float型,再求平均值*/

order=0;

/*未排序前此值为0*/

next=head;

/*将头结点做为新输入结点的后继结点*/

head=p;

/*新输入结点为新的头结点*/

return(head);

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

voidprint(STUDENT*head)

{inti=0;

/*统计记录条数*/

STUDENT*p;

/*移动指针*/

p=head;

/*初值为头指针*/

\n**********************************学生成绩表**********************************\n"

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

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

while(p!

=NULL)

i++;

|%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;

**************************************结束**************************************\n"

/*排序函数*/

STUDENT*sort(STUDENT*head)

/*保存名次*/

STUDENT*p1,*p2,*t,*temp;

/*定义临时指针*/

temp=head->

/*将原表的头指针所指的下一个结点作头指针*/

head->

next=NULL;

/*第一个结点为新表的头结点*/

while(temp!

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

t=temp;

/*取原表的头结点*/

temp=temp->

/*原表头结点指针后移*/

p1=head;

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

p2=head;

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

while(t->

average<

p1->

average&

&

p1!

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

p2=p1;

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

p1=p1->

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

t->

next=p1;

/*待排序点的后继为p*/

head=t;

/*新头结点为待排序点*/

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

/*t的后继是p1*/

p2->

next=t;

/*p2的后继是t*/

p1=head;

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

while(p1!

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

/*结点序号*/

p1->

order=i;

/*将结点序号赋值给名次*/

/*指针后移*/

排序成功\n"

/*排序成功*/

return(head);

/*删除记录函数*/

STUDENT*delete(STUDENT*head)

{intn=0;

STUDENT*p1,*p2;

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

charc,s[6];

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

请输入要删除的学生的学号:

"

scanf("

s);

p1=p2=head;

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

while(strcmp(p1->

num,s)&

p1!

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

{p2=p1;

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

/*将p1指针指向下一条记录*/

if(strcmp(p1->

num,s)==0)/*学号找到了*/

**************************************信息如下************************************\n"

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

|%s|%s|%d|%d|%d|%d|%f|%d|\n"

num,p1->

name,p1->

score[0],p1->

score[1],p1->

score[2],p1->

sum,p1->

average,p1->

***************************************结束**************************************\n"

确定要删除吗?

Y/N?

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

for(;

{scanf("

%c"

c);

if(c=='

n'

||c=='

N'

/*如果不删除,则跳出本循环*/

y'

Y'

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

head=p1->

/*把第二个结点地址赋予head*/

else

next=p1->

/*否则将一下结点地址赋给前一结点地址*/

n=n-1;

\n学号%s已删除\n"

请保存\n"

/*删除后就跳出循环*/

\n没有找到该生\n"

/*找不到该结点*/

return(head);

/*查找记录函数*/

voidsearch(STUDENT*head)

{STUDENT*p;

/*移动指针*/

chars[5];

/*存放姓名用的字符数组*/

请输入要查找的姓名\n"

/*将头指针赋给p*/

while(strcmp(p->

name,s)&

p!

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

/*移动指针,指向下一结点*/

if(p!

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

\n*************************************查找************************************\n"

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

\n没有该学生\n"

/*显示没有该学生*/

/*插入记录函数*/

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

{STUDENT*p0,*p1,*p2;

intn=0,sum1,i;

/*使p1指向第一个结点*/

p0=new;

/*p0指向要插入的结点*/

\n请输入一个新记录\n"

/*提示输入记录信息*/

输入学号:

new->

请输入成绩\n"

sum1=0;

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

for(i=0;

i++)

new->

if(new->

100||new->

0)

}while(new->

0);

sum1=sum1+new->

sum=sum1;

/*将总分存入新记录中*/

average=(float)sum1/3;

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

{head=p0;

p0->

}/*使p0指向的结点作为头结点*/

else

{while((p0->

average)&

(p1->

next!

=NULL))

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

/*p1后移一个结点*/

if(p0->

average>

=p1->

average)

{if(head==p1)head=p0;

/*插到原来第一个结点之前*/

elsep2->

next=p0;

/*插到p2指向的结点之后*/

p0->

{p1->

}/*插到最后的结点之后*/

n=n+1;

/*结点数加1*/

/*调用排序的函数,将学生成绩重新排序*/

\n学生

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

当前位置:首页 > 总结汇报 > 学习总结

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

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