C语言学生成绩管理系统设计报告文档格式.docx
《C语言学生成绩管理系统设计报告文档格式.docx》由会员分享,可在线阅读,更多相关《C语言学生成绩管理系统设计报告文档格式.docx(43页珍藏版)》请在冰豆网上搜索。
score*search()函数:
用来查询学生成绩,传递给函数指向链表的头指针,查询时,如果找到与输入相匹配的学号则打印此学生,反之则输出“没有任何学生资料!
”:
score*sortdata()函数:
该函数有学号、姓名、单科成绩排序(冒泡排序法),实行过程如图:
save()函数:
用来保存数据,首先从用户输入取得要保存的文件名,然后定义一个指向文件的指针,以读写方式打开文件。
将写生信息依次存入文件。
score*load()函数:
用于读取数据,通过“r+”方式打开文件并判断是否打开成功。
具体实现如下:
score*statistics()函数:
它能实现程序的统计,通过switch-case语句选择统计方式,通过循环计算总分或者平均分并打印出来,流程都是通过循环,让指针逐个遍历整个链表,读取相应的数据并实现统计
3.2数据结构设计
数据结构:
定义了一个包含学生成绩信息的结构体(structscorenode{}),学生信息包括学号(number)、姓名(name[10])、语文、数学、英语成绩(chinese、mathmatic、english)、以及指向下一个结构体的链表指针(structscorenode*next)。
3.3函数功能描述
main()函数:
主函数功能主要是让程序选择将要进行的操作,通过menu()函数返回的选项进入其他函数执行。
intmenu(intk)函数:
此函数显示主菜单内容,需要一个int类型变量作为输入要执行的选项并返回给main()函数。
此函数用于创建链表,为了节省内存空间,我们采用malloc()函数为结构体分配动态内存空间。
另外考虑到学号不可能是0,所以用输入0的方式来判断是否结束输入,将最后的结构体中的指针指向NULL,并返回一个指向链表第一个结构的指针。
voidprint(score*head)函数:
此函数返回值为空,知识为了在stdout流(屏幕)上打印出学生的成绩信息,需要一个指向链表头的指针来逐个向后打印。
score*add(score*head,score*stu)函数:
为学生信息中添加新的学生资料,然后重新排序(按学号),并返回头指针。
传入函数的head为链表头指针,stu指针指的是要添加的位置。
score*search(score*head)函数:
按照学号查找学生信息,需要链表头指针并返回指向被搜索学生的指针。
搜索原理就是从头向后面依次检索。
score*dele(score*head)函数:
删除指定学生的资料。
传入头指针,在函数中创建变量储存要删除学生的学号,然后从头向尾检索,直至找到该学生并将其删除,返回头指针。
score*sortdata(score*head)函数:
用于按要求(学号、姓名、单科成绩)排序,最后返回头指针,排序运用老师上课时讲过的冒泡排序法。
intsave(score*p1)函数:
将链表内的数据以文件的形式储存,传入的p1指针一开始指向链表头,随着储存顺序一个一个地向后面指,直到NULL为止。
函数内部定义一个指向文件的指针*fp,用于写入文件。
score*load(score*head)函数:
读取文件数据,head为一个新建的链表头指针,读取文件数据之后令其保存至新建的链表之中,并返回头指针。
score*statistics(score*head)函数:
统计成绩,可以统计总分、平均分、最高(低)分,返回操作后的链表首地址(头指针)。
4、程序实现
4.1源代码
#include<
malloc.h>
stdio.h>
#include<
stdlib.h>
string.h>
#defineLENsizeof(structscorenode)
#defineDEBUG
/*===========数据结构==========*/
structscorenode
{
intnumber;
//学生学号
charname[10];
//学生姓名
floatchinese;
//语文成绩
floatmathmatic;
//数学成绩
floatenglish;
//英语成绩
structscorenode*next;
};
typedefstructscorenodescore;
//定义结构体变量
typedefstructscorenode*scoreptr;
//定义结构体变量指针
intn,k;
/*n,k为全局变量,本程序中的函数均可以使用它,分别用于记数和标记*/
/*==========创建链表==========*/
/*返回一个指向链表头的指针*/
score*creatlink()
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:
请输入学生学号(学号应大于0):
"
//输入学号,学号应大于0
scanf("
%d"
&
p1->
number);
while(p1->
number<
0)
{
getchar();
printf("
输入错误,请重新输入学生学号:
scanf("
}//输入学号为字符或小于0时,程序报错,提示重新输入学号
if(p1->
number==0)
gotoend;
//当输入的学号为0时,转到末尾,结束创建链表
else
{
p3=head;
if(n>
{
for(i=0;
i<
n;
i++)
{
if(p1->
number!
=p3->
number)
p3=p3->
next;
else
{
printf("
学号重复,请重输!
gotorepeat1;
/*当输入的学号已经存在,程序报错,返回前面重新输入*/
}
}
}
}
请输入学生姓名:
%s"
name);
/*输入学生姓名*/
请输入语文成绩(0~100):
/*输入语文成绩,成绩应在0-100*/
%f"
chinese);
chinese<
0||p1->
chinese>
100)
输入错误,请重新输入语文成绩"
/*输入错误,重新输入语文成绩直到正确为止*/
请输入数学成绩(0~100):
/*输入数学成绩,成绩应在0-100*/
mathmatic);
mathmatic<
mathmatic>
输入错误,请重新输入数学成绩"
/*输入错误,重新输入数学成绩直到正确为止*/
请输入英语成绩(0~100):
/*输入英语成绩,成绩应在0-100*/
english);
english<
english>
输入错误,请重新输入英语成绩"
}/*输入错误,重新输入英语成绩直到正确为止*/
head=NULL;
=0)
n=n+1;
if(n==1)
head=p1;
else
p2->
next=p1;
p2=p1;
p1=(score*)malloc(LEN);
repeat2:
printf("
/*输入学号*/
while(p1->
getchar();
printf("
输入错误,请重新输入学生学号:
scanf("
}/*输入学号为字符或小于0时,程序报错,提示重新输入学号*/
if(p1->
gotoend;
/*当输入的学号为0时,转到末尾,结束创建链表*/
p3=head;
if(n>
for(i=0;
if(p1->
p3=p3->
else
{
printf("
gotorepeat2;
/*当输入的学号已经存在,程序报错,返回前面重新输入*/
}
}
}
/*输入语文成绩,成绩应在0-100*/
}/*输入错误,重新输入语文成绩直到正确为止*/
}/*输入错误,重新输入数学成绩直到正确为止*/
}/*输入错误,重新输入英语成绩直到正确为止*/
end:
p1=head;
p3=p1;
for(i=1;
for(j=i+1;
j<
=n;
j++)
max=p1;
p1=p1->
if(max->
number>
k=max->
number;
max->
number=p1->
p1->
number=k;
/*交换前后结点中的学号值,使得学号大者移到后面的结点中*/
strcpy(t,max->
strcpy(max->
name,p1->
strcpy(p1->
name,t);
/*交换前后结点中的姓名,使之与学号相匹配*/
fen=max->
chinese;
chinese=p1->
chinese=fen;
/*交换前后结点中的语文成绩,使之与学号相匹配*/
mathmatic;
mathmatic=p1->
mathmatic=fen;
/*交换前后结点中的数学成绩,使之与学号相匹配*/
english;
english=p1->
english=fen;
/*交换前后结点中的英语成绩,使之与学号相匹配*/
}
max=head;
p1=head;
/*重新使max,p指向链表头*/
}
p2->
next=NULL;
/*链表结尾*/
输入的学生数为:
%d个!
n);
return(head);
}
/*==========显示数据==========*/
/*函数print,功能:
显示学生成绩*/
voidprint(score*head)
score*p;
if(head==NULL)
{printf("
\n没有任何学生资料!
{
%d\n"
-----------------------------------------\n"
|学号\t|姓名\t|语文\t|数学\t|英语\t|\n"
/*打印表格域*/
p=head;
do
|%d\t|%s\t|%.1f\t|%.1f\t|%.1f\t|\n"
p->
number,p->
name,p->
chinese,p->
mathmatic,p->
/*打印表格域*/
p=p->
}while(p!
=NULL);
/*==========添加学生数据==========*/
/*函数add,功能:
追加学生资料,并且将所有学生资料按学号排序*/
score*add(score*head,score*stu)
score*p0,*p1,*p2,*p3,*max;
p3=stu=(score*)malloc(LEN);
/*开辟一个新单元*/
\n输入要增加的学生的资料!
repeat4:
stu->
/*输入学号,学号应大于0*/
while(stu->
}/*输入错误,重新输入学号*/
if(stu->
number==0)
gotoend2;
/*当输入的学号为0时,转到末尾,结束追加*/
p3=head;
if(n>
{for(i=0;
if(stu->
p3=p3->
else
printf("
gotorepeat4;
/*当输入的学号已经存在,程序报错,返回前面重新输入*/
输入学生姓名:
stu->
/*输入学生姓名*/
0||stu->
{getchar();
}/*输入错误,重新输入语文成绩直到正确为止*/
/*输入数学成绩,成绩应在0-100*/
}/*输入错误,重新输入数学成绩直到正确为止*/
/*输入英语成绩,成绩应在0-100*/
}/*输入错误,重新输入英语成绩直到正确为止*/
p0=stu;
if(head==NULL)
head=p0;
p0->
}/*当原来链表为空时,从首结点开始存放资料*/
else/*链表不为空*/
next==NULL)/*找到原来链表的末尾*/
p1->
next=p0;
p0->
/*将它与新开单元相连接*/
next!
=NULL)/*还没找到末尾,继续找*/
p2=p1;
p1=p1->
n=n+1;
for(j=i+1;
max=p1;
p1=p1->
if(max->
k=max->
max->
p1->
/*交换前后结点中的学号值,使得学号大者移到后面的结点中*/
strcpy(t,max->
strcpy(max->
strcpy(p1->
/*交换前后结点中的姓名,使之与学号相匹配*/
fen=max->
/*交换前后结点中的语文成绩,使之与学号相匹配*/
/*交换前后结点中的数学成绩,使之与学号相匹配*/
/*交换前后结点中的英语成绩,使之与学号相匹配*/
max=head;
p1=head;
/*重新使max,p指向链表头*/
}end2:
现在的