C语言学生成绩管理系统设计报告文档格式.docx

上传人:b****7 文档编号:22046551 上传时间:2023-02-02 格式:DOCX 页数:43 大小:734.72KB
下载 相关 举报
C语言学生成绩管理系统设计报告文档格式.docx_第1页
第1页 / 共43页
C语言学生成绩管理系统设计报告文档格式.docx_第2页
第2页 / 共43页
C语言学生成绩管理系统设计报告文档格式.docx_第3页
第3页 / 共43页
C语言学生成绩管理系统设计报告文档格式.docx_第4页
第4页 / 共43页
C语言学生成绩管理系统设计报告文档格式.docx_第5页
第5页 / 共43页
点击查看更多>>
下载资源
资源描述

C语言学生成绩管理系统设计报告文档格式.docx

《C语言学生成绩管理系统设计报告文档格式.docx》由会员分享,可在线阅读,更多相关《C语言学生成绩管理系统设计报告文档格式.docx(43页珍藏版)》请在冰豆网上搜索。

C语言学生成绩管理系统设计报告文档格式.docx

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:

现在的

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

当前位置:首页 > PPT模板 > 其它模板

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1