C语言学生成绩管理系统实验分析报告Word下载.docx
- 文档编号:14967909
- 上传时间:2022-10-26
- 格式:DOCX
- 页数:15
- 大小:63.41KB
C语言学生成绩管理系统实验分析报告Word下载.docx
《C语言学生成绩管理系统实验分析报告Word下载.docx》由会员分享,可在线阅读,更多相关《C语言学生成绩管理系统实验分析报告Word下载.docx(15页珍藏版)》请在冰豆网上搜索。
4.排序
5.查询
6.退出
②若输入1,则进入新建数据界面。
根据提示依次输入学生人数、学生的学号、姓名、数学成绩和程序设计程序。
S1:
输入学生人数n,
S2:
0->
i,(把0放在变量i中)
S3:
输入第i+1个学生的数据(学号,姓名,学数学成绩,程序设计成绩)
S4:
i+1->
i
S5:
若i<
n,返回S2,否则继续
S6:
0=<
S7:
输出第i+1个学生数据
S8:
i+1=i
N,返回s6否则结束算法
③输入2,进入添加数据界面。
S1:
原有学生人数n加1,即n+1=>
n
输入学生数据
0->
输出第i+1个学生的数据
n返回S4,否则结束算法
④输入3进入删除数据界面。
输入要删除的学生学号m
i,0->
j
若学生的学号stu[i].num,转到S6,否则继续
n,返回S3,否则输出“输出的学号不存在”算法接速
n-1->
n
把要删除的数据覆盖
stu[i].num=>
stu[j].num;
stu[i].name=>
stu[j].name;
stu[i].math=stu[j].math;
stu[i].C=stu[j].C;
j++;
n,返回S7,否则继续
S9:
S10:
S11:
n返回S10,否则结束算法
⑤输入4,进入排序界面。
按三种方式排序本质一样一下用数组a[50]代表
若a[i]<
a[j],第i+1个学生数据与第j+1个学生数据进行交换
j+1->
若j<
n,n为学生原有人数,返回S3
S7:
n-1,返回S2
s8:
输出学生数据,算法结束
⑥输入5,进入查询界面。
1)按学号和名字方法一样(以按学号为例)
输入要查询的学生的学号置于a[10]中
若stu[i].num=a[10],输出该生数据并结束
n返回S3否则输出“学号不存在”,算法结束
(2)按数学、程序设计、总分查询(以数学为例)
输入最低分数线m
S2:
i,0->
若std[i].math=m,转到S6
S5:
n,返回S3
strcpy(e[j],stu[i].num);
strcpy(b[j],stu[i].name);
c[j]=stu[i].math;
d[j]=stu[i].C;
(其中数组e,b,c,d是二维数组)
j,返回S3
输出学生数据
i<
j,返回S9,否则算法结束
⑦输入6,结束,退出程序
㈤程序清单
#include<
string.h>
stdio.h>
#defineN50
intn;
structstudent
{
charnum[10];
charname[20];
intmath,C,sum;
}stu[N];
voidput1()
voidput2();
put2();
printf("
\t\t\t\t学生成绩管理系统\n\t\t\t\t-----------------------\n"
);
\t\t\t\t|1.新建数据|\n"
\t\t\t\t|2.添加数据|\n"
\t\t\t\t|3.删除数据|\n"
\t\t\t\t|4.排序|\n"
\t\t\t\t|5.查询|\n"
\t\t\t\t|6.退出|\n"
\n"
}
voidput2()
********************************************************************************\n"
voidput3()
学号姓名数学程序设计总分\n"
voidput4()
printf("
操作结果如下:
voidget(inti)
\t\t\t请输入学号:
"
scanf("
%s"
stu[i].num);
\t\t\t请输入姓名:
stu[i].name);
\t\t\t请输入数学成绩:
scanf("
%d"
&
stu[i].math);
\t\t\t请输入程序设计成绩:
stu[i].C);
voidbuild()
\n\t\t\t新建数据\n"
inti;
\n\t\t\t请输入学生人数:
n);
for(i=0;
n;
i++)
get(i);
put4();
put2();
put3();
%-6s%-6s%4d%8d%8d\n"
stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);
voidadd()
\n\t\t\t添加数据\n\n"
n=n+1;
get(n-1);
put4();
voiddelet()
charstr[10];
inti,j=0,k=0;
\n\t\t\t删除数据\n\n"
\t\t\t请输入要删除的学生的学号:
str);
{
if(strcmp(str,stu[i].num)==0)k++;
else
stu[j].num=stu[i].num;
stu[j].name=stu[i].name;
stu[j].math=stu[i].math;
stu[j].C=stu[i].C;
}
if(k==0)printf("
\t\t\t输入的学号不存在\n"
n=n-1;
voidsort_1(inta[])
inti,j,k,m,t;
charstr[20];
n-1;
for(j=i+1;
j<
j++)
if(a[i]<
a[j])
strcpy(str,stu[i].num);
strcpy(stu[i].num,stu[j].num);
strcpy(stu[j].num,str);
strcpy(str,stu[i].name);
strcpy(stu[i].name,stu[j].name);
strcpy(stu[j].name,str);
t=stu[i].math;
stu[i].math=stu[j].math;
stu[j].math=t;
t=stu[i].C;
stu[j].C=t;
voidsort()
inti,q;
intmat[N],c[N],su[N];
loot:
for(i=0;
{mat[i]=stu[i].math;
c[i]=stu[i].C;
su[i]=stu[i].math+stu[i].C;
\n\t\t\t成绩排序\n\n"
\t\t\t1.数学成绩排序\n\t\t\t2.程序设计排序\n\t\t\t3.总分排序\n\t\t\t4.返回主菜单\n"
\t\t\t请选择排序方式序号1-4:
q);
if(q==1){sort_1(mat);
\t\t\t\n\n"
gotoloot;
elseif(q==2){sort_1(c);
gotoloot;
elseif(q==3){sort_1(su);
elseif(q==4);
voidseek_num()
inti,k=0;
if(strcmp(str,stu[i].num)==0)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 学生 成绩管理系统 实验 分析 报告