C语言 学生成绩管理系统实验报告精编版.docx

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

C语言 学生成绩管理系统实验报告精编版.docx

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

C语言 学生成绩管理系统实验报告精编版.docx

C语言学生成绩管理系统实验报告精编版

学生成绩管理系统实验报告

㈠实验名称:

学生成绩管理系统

㈡实验目的:

1)利用所学的三种程序基本结构以及数组、用户自定义函数进行一个简单管理系统的设计,进一步理解和掌握c语言的语法以及三种基本程序结构的综合应用。

2)通过程序中设计到的排序、查找、求和等操作加深对算法、程序设计思路、常用程序设计技巧的理解与掌握,逐步培养学生的程序开发能力。

㈢实验要求:

设某班有n位同学,每位同学的数据包括一下内容:

学号(长整型)、姓名(字符号)、数学成绩(整型)、程序设计成绩(整型)。

设计程序完成以下5项功能:

新建数据档案、添加数据、删除数据、对输入的数据进行排序和查询。

㈣算法内容:

①程序运行,利用printf函数显示主菜单,并提示输入相应的数字来进行相关操作。

显示主菜单如下:

1.新建数据

2.添加数据

3.删除数据

4.排序

5.查询

6.退出

②若输入1,则进入新建数据界面。

根据提示依次输入学生人数、学生的学号、姓名、数学成绩和程序设计程序。

S1:

输入学生人数n,

S2:

0->i,(把0放在变量i中)

S3:

输入第i+1个学生的数据(学号,姓名,学数学成绩,程序设计成绩)

S4:

i+1->i

S5:

若i

S6:

0=

S7:

输出第i+1个学生数据

S8:

i+1=i

若i

③输入2,进入添加数据界面。

S1:

原有学生人数n加1,即n+1=>n

S2:

输入学生数据

S3:

0->i

S4:

输出第i+1个学生的数据

S5:

若i

④输入3进入删除数据界面。

S1:

输入要删除的学生学号m

S2:

0->i,0->j

S3:

若学生的学号stu[i].num,转到S6,否则继续

S4:

i+1->i

S5:

若i

S6:

n-1->n

S7:

把要删除的数据覆盖

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

S8:

若i

S9:

0->i

S10:

输出第i+1个学生的数据

S11:

若i

⑤输入4,进入排序界面。

按三种方式排序本质一样一下用数组a[50]代表

S1:

0->i

S2:

i+1->j

S3:

若a[i]

S4:

j+1->j

S5:

若j

S6:

i+1->i

S7:

若i

s8:

输出学生数据,算法结束

⑥输入5,进入查询界面。

1)按学号和名字方法一样(以按学号为例)

S1:

输入要查询的学生的学号置于a[10]中

S2:

0->i

S3:

若stu[i].num=a[10],输出该生数据并结束

S4:

i+1->i

S5:

若i

(2)按数学、程序设计、总分查询(以数学为例)

S1:

输入最低分数线m

S2:

0->i,0->j

S3:

若std[i].math=m,转到S6

S4:

i+1->i

S5:

若i

S6:

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是二维数组)

S7:

j+1->j,返回S3

S8:

0->i

S9:

输出学生数据

S10:

i+1->i

S11:

i

⑦输入6,结束,退出程序

㈤程序清单

#include

#include

#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");

printf("\t\t\t\t|1.新建数据|\n");

printf("\t\t\t\t|2.添加数据|\n");

printf("\t\t\t\t|3.删除数据|\n");

printf("\t\t\t\t|4.排序|\n");

printf("\t\t\t\t|5.查询|\n");

printf("\t\t\t\t|6.退出|\n");

put2();

printf("\n");

}

voidput2()

{

printf("********************************************************************************\n");

}

voidput3()

{

printf("学号姓名数学程序设计总分\n");

}

voidput4()

{

printf("操作结果如下:

\n");

}

voidget(inti)

{

printf("\t\t\t请输入学号:

");scanf("%s",stu[i].num);

printf("\t\t\t请输入姓名:

");scanf("%s",stu[i].name);

printf("\t\t\t请输入数学成绩:

");

scanf("%d",&stu[i].math);

printf("\t\t\t请输入程序设计成绩:

");

scanf("%d",&stu[i].C);printf("\n");

}

voidbuild()

{

printf("\n\t\t\t新建数据\n");

inti;

printf("\n\t\t\t请输入学生人数:

");

scanf("%d",&n);printf("\n");

for(i=0;i

get(i);printf("\n");

put4();put2();put3();

for(i=0;i

printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);

put2();

}

voidadd()

{

printf("\n\t\t\t添加数据\n\n");

inti;n=n+1;

get(n-1);put4();

put2();put3();

for(i=0;i

printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);

put2();

}

voiddelet()

{

charstr[10];inti,j=0,k=0;printf("\n\t\t\t删除数据\n\n");

printf("\t\t\t请输入要删除的学生的学号:

");

scanf("%s",str);

for(i=0;i

{

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;j++;

}

}

if(k==0)printf("\t\t\t输入的学号不存在\n");

else

{

put4();put2();put3();n=n-1;

for(i=0;i

printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);

put2();

}

}

voidsort_1(inta[])

{

inti,j,k,m,t;charstr[20];

for(i=0;i

for(j=i+1;j

if(a[i]

{

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[i].C=stu[j].C;stu[j].C=t;

}

put4();put2();put3();

for(i=0;i

printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);

put2();

}

voidsort()

{

inti,q;intmat[N],c[N],su[N];

loot:

for(i=0;i

{mat[i]=stu[i].math;c[i]=stu[i].C;su[i]=stu[i].math+stu[i].C;}

printf("\n\t\t\t成绩排序\n\n");put2();

printf("\t\t\t1.数学成绩排序\n\t\t\t2.程序设计排序\n\t\t\t3.总分排序\n\t\t\t4.返回主菜单\n");

put2();

printf("\t\t\t请选择排序方式序号1-4:

");

scanf("%d",&q);

if(q==1){sort_1(mat);printf("\t\t\t\n\n");gotoloot;}

elseif(q==2){sort_1(c);printf("\t\t\t\n\n");gotoloot;}

elseif(q==3){sort_1(su);printf("\t\t\t\n\n");gotoloot;}

elseif(q==4);

}

voidseek_num()

{

charstr[10];inti,k=0;

printf("\t\t\t请输入学号:

");

scanf("%s",str);

for(i=0;i

if(strcmp(str,stu[i].num)==0)

{

put4();put2();put3();

printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);

put2();break;

}

if(i==n)printf("\t\t\t输入的学号不存在");

}

voidseek_name()

{

charstr[10];inti,k=0;

printf("\t\t\t请输入姓名:

");

scanf("%s",str);

for(i=0;i

if(strcmp(str,stu[i].name)==0)

{

put4();put2();put3();

printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);

put2();break;

}

if(i==n)printf("\t\t\t输入的姓名不存在");

}

voidseek_1(inta[N])

{inti,m,j=0,k;chare[50][50],b[50][50];intc[50],d[50];

printf("\t\t\t请输入分数下线:

");

scanf("%d",&m);

for(i=0;i

if(a[i]>=m)

{

strcpy(e[j],stu[i].num);

strcpy(b[j],stu[i].name);

c[j]=stu[i].math;

d[j]=stu[i].C;j++;

}

put4();put2();put3();

for(i=0;i

printf("%-6s%-6s%4d%8d%8d\n",e[i],b[i],c[i],d[i],c[i]+d[i]);

put2();

}

voidseek()

{

inti,q;intmat[N],c[N],su[N];

for(i=0;i

{mat[i]=stu[i].math;c[i]=stu[i].C;su[i]=stu[i].math+stu[i].C;}

looa:

printf("\n\t\t\t成绩查询\n\n");

put2();

printf("\t\t\t1.学号查询\n2.姓名查询\n3.数学成绩查询\n4.程序设计查询\n5.总分排序查询\n6.返回主菜单\n");

put2();printf("\t\t\t请选择查询方式1-6:

");

scanf("%d",&q);

if(q==1){seek_num();printf("\n\n");gotolooa;}

elseif(q==2){seek_name();printf("\n\n");gotolooa;}

elseif(q==3){seek_1(mat);printf("\n\n");gotolooa;}

elseif(q==4){seek_1(c);printf("\n\n");gotolooa;}

elseif(q==5){seek_1(su);printf("\n\n");gotolooa;}

elseif(q==6);

}

voidmain()

{

inti,q;intmat[N],c[N],su[N];

for(i=0;i

{mat[i]=stu[i].math;c[i]=stu[i].C;su[i]=stu[i].math+stu[i].C;}

loop:

put1();

printf("\t\t\t如果还没新建数据,请先新建数据\n\n");

printf("\t\t\t请选择要操作步骤的序号1-6:

");

scanf("%d",&q);

if(q==1)

{

build();printf("\n\n");gotoloop;

}

elseif(q==2)

{

add();printf("\n\n");gotoloop;

}

elseif(q==3)

{

delet();printf("\n\n");gotoloop;

}

elseif(q==4)

{

sort();printf("\n\n");gotoloop;

}

elseif(q==5)

{

seek();printf("\n\n");gotoloop;

}

elseif(q==6)

{

printf("\t\t\t\n\n\t\t\t谢谢使用!

\n\n\n");

}

}

㈥运行结果

原始界面

新建数据

添加数据

删除数据

成绩排序

成绩查询

退出界面

㈦分析与思考

C语言的确是一门很难学的课程。

原本以为做个程序是件简单的事情,但是想错了。

要完完整整把程序按照要求编出来是意见很不容易的事情。

从开始看题目,一个个分部分的分析、设计、写算法等等,真的是头疼啊!

虽然有些地方可以套用书上或者知道书上的例题,但是一点点把程序拼接起来,一步步修改还是好艰难的啊。

只能向同学求助,帮忙一起弄弄程序!

所以元旦放假这几天经常去图书馆上个机,搞搞程序,把程序中的上百个错误一点点减少到零个,出现我们想要的操作界面。

这个上交的程序是我们比较满意的,但还是有些地方还不够好。

比如说数据编排还不够美观,虽然作了较多的努力,但是结果都不是很理想,最后还是放弃了,只能这样勉强看看。

这个程序下来,我觉得做程序需要很大的耐心,一个大点的程序有个几百甚至上千个步骤,没有耐心是做不成功的。

当然细心也很需要,有很多错误都是自己的粗心造成的,有时甚至自己以遍遍检查都看不出来,还以为是什么大错误呢。

但是即使是有一点点小错误,编的再怎么完美的程序也无法正常运行。

所以编程序也是在锻炼一个人啊。

现在觉得我们学的东西还是比较少的,一个稍微大点的程序就把我们弄的这么痛苦,还是要多学点,多实践,才能真正掌握好。

在以后的日子,要想把编程学好还是要下很大一番苦功夫的啊,所以要努力了啊!

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

当前位置:首页 > 医药卫生 > 基础医学

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

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