C语言程序设计-学生成绩管理系统文档格式.doc
- 文档编号:6941640
- 上传时间:2023-05-07
- 格式:DOC
- 页数:26
- 大小:144.50KB
C语言程序设计-学生成绩管理系统文档格式.doc
《C语言程序设计-学生成绩管理系统文档格式.doc》由会员分享,可在线阅读,更多相关《C语言程序设计-学生成绩管理系统文档格式.doc(26页珍藏版)》请在冰点文库上搜索。
2.显示主菜单函数voidDispMainMenu()
这是一个无参函数,用来显示程序主菜单,用户通过输入对应功能前的数字来实现相应的功能
3.学生成绩录入函数intInformationInput(STUDENTstu[],intcn)
这是一个有返回值的有参函数,形参STUDENTstu[]为结构体数组指针,表示存有学生信息的结构体数组的头指针,形参intcn为当前学生人数,返回值为当前学生人数。
其作用是输入有限个学生的成绩信息。
算法:
定义3个变量,num用来存放本次录入学生人数,i、j为循环变量。
由键盘输入学生人数赋值给num,判断num是否大于MAX_NUM(2000),若大于,则提示输入人数太多,函数返回值0;
若不大于,则依次输入num个学生信息。
4.显示所有学生信息函数voidDispInformation(STUDENTstu[],intMAX)
这是一个无返回值的有参函数,形参STUDENTstu[]为结构体数组指针,表示存有学生信息的结构体数组的头指针,形参intMAX为为当前学生人数。
其作用是现实当前所有学生成绩信息。
5.查找指定学号的学生的信息函数intFindStudentnumber(STUDENTstu[],intfindnumber,intMAX)
这是一个有返回值的有参函数,形参STUDENTstu[]为结构体数组指针,表示存有学生信息的结构体数组的头指针,形参intMAX为当前学生人数。
其作用是根据指定学号查询学生成绩信息,若查找到指定学号学生信息,则返回该学生学号,否则返回-1。
6.查找指定姓名的学生的信息函数intFindStudentname(STUDENTstu[],charfindname[],intMAX)
其作用是根据指定姓名查询学生成绩信息,若查找到指定姓名学生信息,则返回该学生学号,否则返回-1。
7.学生信息查询函数voidQueryInformation(STUDENTstu[],intMAX)
这是一个无返回值的有参函数,形参STUDENTstu[]为结构体数组指针,表示存有学生信息的结构体数组的头指针,形参intMAX为当前学生人数。
其作用是可以根据学号或姓名查找到指定学生的成绩信息。
定义查询方式字符变量select,指定学号整型变量findnumber,指定姓名字符串数组findname[10],整型变量i,循环变量j。
调用函数时,屏幕提示选择查询方式,若选择按学号查询,则输入学号后调用查找指定学号的学生的信息函数intFindStudentnumber(STUDENTstu[],intfindnumber,intMAX)将返回值赋给变量i,若变量i不为-1,则查找成功,输出学生信息,否则在屏幕显示“输入学号不存在”;
若选择按姓名查询则输入姓名后调用查找指定姓名的学生的信息函数intFindStudentname(STUDENTstu[],charfindname[],intMAX)将返回值赋给i,若变量i不为-1,则查找成功,输出学生信息,否则在屏幕显示“输入学号不存在”。
若在选择查询方式时输入除“1”、“2”外的其他字符,则提示“选择错误”。
N-S图
8.修改学生信息函数voidEditInformation(STUDENTstu[],intMAX)
其作用是修改或删除指定学生的成绩信息。
定义整型变量i、j,j为循环变量;
浮点型变量sum,用来寻访总成绩;
整形变量findnum用来存放需要修改信息的学生学号;
字符变量select用来存放修改方式代号。
输入学号后调用查找指定学号的学生的信息函数intFindStudentnumber(STUDENTstu[],intfindnumber,intMAX)将返回值赋给变量i,若变量i不为-1,则存在该学号学生。
在屏幕提示选择修改方式,若选择修改信息,则先在屏幕输出原信息,后按提示依次修改信息;
若选择删除信息,则调用删除信息函数voidDelete(STUDENTstu[],intn,intMAX)删除该学号学生信息。
若未查找到指定学号,则在屏幕输出“您输入的学号不存在”。
9.按学号排序函数voidSortNum(STUDENTstu[],intMAX)
其作用是用冒泡法将学生成绩信息按学号由小到大排列。
定义循环变量i、j,结构体变量p作为中间变量。
冒泡法完成排序后,调用显示所有学生信息函数voidDispInformation(STUDENTstu[],intMAX)在屏幕打印出排序后的学生成绩信息。
10.按平均成绩排序函数voidSortScore(STUDENTstu[],intMAX)
其作用是用冒泡法将学生成绩信息按平均成绩由大到小排列。
11.保存数据到文件函数voidSave(STUDENTstu[],intMAX)
其作用是将存放在结构体数组中的学生成绩信息保存到文件Information.txt中。
定义整型变量i,文件指针*fp。
若成功打开文件Information.txt,则用fwrite()将存放在结构体数组中的学生成绩信息保存到文件Information.txt中;
若打开失败,则在屏幕输出“cannotopenfile”。
12.打开数据文件函数intRead(STUDENTstu[])
这是一个有返回值的有参函数,形参STUDENTstu[]为结构体数组指针,表示存有学生信息的结构体数组的头指针,返回值为读取到的学生信息个数,即学生人数。
其作用是将存放在文件Information.txt中的学生成绩信息存放到结构体数组中。
若成功打开文件Information.txt,则计数变量赋值为0,每完成一次读取,i自加1。
13.删除信息函数voidDelete(STUDENTstu[],intn,intMAX)
这是一个无返回值的有参函数,形参STUDENTstu[]为结构体数组指针,表示存有学生信息的结构体数组的头指针,形参intn表示血药删除的学生序号,形参intMAX为当前学生人数。
其作用是删除第n个学生的信息。
定义循环变量i、j,文件指针*fp。
打开存有学生成绩信息的文件Information.txt,在屏幕显示源信息。
然后将存放在结构体数组中的信息,从第n个开始,之后每一组数据覆盖前一组数据,以达到删除信息的同时又保证结构体数组中信息连续的目的。
之后当前学生人数自减1,重新保存数据到文件Information.txt,在屏幕输出当前所有学生信息。
五、调试分析
1.运行时输入信息没有按照scanf()函数格式输入,导致程序无法正常继续运行。
2.按照正确格式输入完信息后按回车键后出现“烫烫烫烫”字样的乱码,后经检查发现在学生成绩输入函数intInformationInput(STUDENTstu[],intcn)中调用了显示所有学生信息函数voidDispInformation(STUDENTstu[],intMAX),而显示所有学生信息函数voidDispInformation(STUDENTstu[],intMAX)中,语句for(i=0;
i<
MAX;
i++)后误按了一个“;
”导致不能正常执行循环体,后经考虑,决定删除输入完后显示学生信息和排序的语句。
3.经2修改后再次运行,出现了运行结果一闪而过的情况,所以上网查找解决方法。
先开始查到的方法是需要添加头文件#include<
conio.h>
并且在需要停留的地方输入语句“getch();
”,再次运行发现运行结果还是一闪而过。
再次查询后,将getch()改为“system("
pause"
);
”。
再次运行能正常显示。
4.经3修改后再次运行,在排序部分,发现按照平均成绩排序时是由小到大排序的,不符合实际应用中最常用的由大到小排序,遂进行修改。
5.经4修改后,在修改信息时,结果不能正常输入学号,检查代码后发现语句“scanf("
%d"
&
stu[i].number);
”中“stu[i].number”前漏掉了取地址符号“&
6.经5修改后,程序能完整运行,但是在查看文件内容是发现信息均为乱码,后有查阅教科书,其解释为fread()和fwrite()一般用于二进制文件的处理。
7.程序运行后,界面内容太多,容易混乱,查询后添加清屏函数“system("
cls"
”
六、总结
经过这次C语言实践活动,我觉得我的C语言水平相对上学期期末又提高了不少。
过去只是对单个知识点较为清楚,如今已经能够形成体系,并且写出有使用价值的程序。
虽然程序很小,但是万事都要有个循序渐进、由易到难的过程。
另外,这次实践对我通过江苏省计算机等级考试(二级C)也有很大的帮助。
过去我们都是软件的使用者,看到的都是软件给我们处理日常事务的便捷之处,如今我们已经能深入后台,自己设计、编写程序了,今后还要躲在易用性和美观上面多下功夫。
我相信,这次实践会成为我今后进行编程、开发的良好开端和基础。
附程序源代码:
/***********************************头文件***********************************/
#include<
stdio.h>
stdlib.h>
string.h>
windows.h>
#defineMAX_NUM2000/*人数上限2000*/
/********************************定义数据结构********************************/
typedefstructstudent
{
intnumber;
/*学号*/
charname[10];
/*姓名*/
floatscore[3];
/*三门课成绩*/
floataver;
/*平均成绩*/
}STUDENT;
/**********************************函数原型**********************************/
voidDispMainMenu();
/*显示主菜单*/
intInformationInput(STUDENTstu[],intcn);
/*学生成绩录入*/
voidDispInformation(STUDENTstu[],intMAX);
/*显示所有学生信息*/
intFindStudentnumber(STUDENTstu[],intfindnumber,intMAX);
/*查找指定学号的学生的信息*/
intFindStudentname(STUDENTstu[],charfindname[],intMAX);
/*查找指定姓名的学生的信息*/
voidQueryInformation(STUDENTstu[],intMAX);
/*学生信息查询*/
voidEditInformation(STUDENTstu[],intMAX);
/*修改学生信息*/
voidSortNum(STUDENTstu[],intMAX);
/*按学号排序*/
voidSortScore(STUDENTstu[],intMAX);
/*按平均成绩排序*/
voidSave(STUDENTstu[],intMAX);
/*保存数据到文件*/
intRead(STUDENTstu[]);
/*打开数据文件*/
voidDelete(STUDENTstu[],intn,intMAX);
/*删除信息*/
/*********************************显示主菜单*********************************/
voidDispMainMenu()
printf("
***********************学生成绩管理系统***********************\n"
\t1.信息录入\t2.按学号排序\n"
\t3.按平均成绩排序\t4.信息修改\n"
\t5.信息查询\t6.保存到数据文件\n"
\t7.打开数据文件\t8.显示所有学生信息\n"
\t0.退出"
\n**************************************************************\n"
请选择0-8:
"
/*显示菜单信息*/
}
/*******************************学生成绩录入*******************************/
intInformationInput(STUDENTstu[],intcn)
intnum,i,j;
floatsum=0;
\n请输入本次录入的学生人数:
scanf("
num);
if(num>
MAX_NUM)
{
printf("
您输入的人数太多,大于%d人!
\n"
MAX_NUM);
system("
return0;
}
for(i=cn;
num+cn;
i++)/*输入num个学生的信息*/
请输入第%d个学生的学号:
i+1);
scanf("
姓名:
%s"
stu[i].name);
语数外成绩:
for(j=0;
j<
3;
j++)
{
scanf("
%f"
stu[i].score[j]);
sum=sum+stu[i].score[j];
}
stu[i].aver=sum/3;
sum=0;
system("
return(num+cn);
/******************************显示所有学生信息******************************/
voidDispInformation(STUDENTstu[],intMAX)
inti,j;
\n序号\t学号\t姓名\t语数外成绩\t\t平均成绩\n"
for(i=0;
i++)
%d\t%d\t%s\t"
i+1,stu[i].number,stu[i].name);
printf("
%.2f\t"
stu[i].score[j]);
%.2f"
stu[i].aver);
/**************************查找指定学号的学生的信息**************************/
intFindStudentnumber(STUDENTstu[],intfindnumber,intMAX)
inti;
if(stu[i].number==findnumber)
break;
if(i<
MAX)/*判断找到的i是否小于MAX,若小于,则执行了break跳出循环,即找到该指定学号的学生*/
returni;
else
return-1;
/**************************查找指定姓名的学生的信息**************************/
intFindStudentname(STUDENTstu[],charfindname[],intMAX)
if(strcmp(stu[i].name,findname)==0)
MAX)/*判断找到的i是否小于MAX,若小于,则执行了break跳出循环,即找到该指定姓名的学生*/
/*******************************学生信息查询*******************************/
voidQueryInformation(STUDENTstu[],intMAX)
charselect;
intfindnumber;
charfindname[10];
************************请选择查询方式************************\n"
\t1.按学号查询;
\t2.按姓名查询\n"
**************************************************************\n"
请选择1或2:
select=getche();
switch(select)
case'
1'
:
\n您选择的是按学号查询\n请输入学生的学号:
/*按学号查询*/
findnumber);
if((i=FindStudentnumber(stu,findnumber,MAX))!
=-1)
\n查找结果如下:
\n学号\t姓名\t语数外成绩\t\t平均成绩\n"
%d\t%s\t"
stu[i].number,stu[i].name);
for(j=0;
printf("
printf("
%.2f\n"
else
您输入的学号不存在!
break;
2'
\n您选择的是按姓名查询\n请输入学生的姓名:
findname);
if((i=FindStudentname(stu,findname,MAX))!
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 学生 成绩管理系统
![提示](https://static.bingdoc.com/images/bang_tan.gif)