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

发布时间:2020-05-19 10:18:15   来源:文档文库   
字号:

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

㈠实验名称:

学生成绩管理系统

㈡实验目的:

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,返回S2 ,否则继续
S6:0=
S7:输出第i+1个学生数据
S8:i+1=i
i返回s6否则结束算法

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

S1:原有学生人数n1,即n+1=>n
S2:输入学生数据
S3:0->i
S4:输出第i+1个学生的数据
S5:i返回S4,否则结束算法

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

S1:输入要删除的学生学号m
S2:0->i0->j
S3:若学生的学号stu[i].num,转到S6,否则继续
S4:i+1->i
S5:i返回S3,否则输出“输出的学号不存在”算法接速
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,返回S7,否则继续

S9:0->i
S10:输出第i+1个学生的数据
S11:i返回S10,否则结束算法

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

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

S1:0->i

S2:i+1->j

S3:a[i],第i+1个学生数据与第j+1个学生数据进行交换

S4:j+1->j

S5:jn为学生原有人数,返回S3

S6:i+1->i

S7:若i,返回S2

s8:输出学生数据,算法结束

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

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

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

S2:0->i

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

S4:i+1->i

S5:i返回 S3否则输出“学号不存在”,算法结束

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

S1:输入最低分数线m

S20->i,0->j

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

S4:i+1->i

S5:若i,返回S3

S6:strcpy(e[j],stu[i].num);strcpy(b[j],stu[i].name);c[j]=stu[i].math;d[j]=stu[i].C;

    (其中数组ebcd 是二维数组)

S7:j+1->j,返回S3

S8:0->i

S9:输出学生数据

S10:i+1->i

S11:i返回S9,否则算法结束

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

㈤程序清单

#include

#include

# define N 50

int n;

struct student

{

char num[10];

char name[20];

int math,C,sum;

}stu[N];

void put1()

{

void put2();

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

}

void put2()

{

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

}

void put3()

{

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

}

void put4()

{

printf("操作结果如下:\n");

}

void get(int i)

{

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

}

void build()

{

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

int i;

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();

}

void add()

{

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

int i; 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();

}

void delet()

{

char str[10];int i,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();

}

}

void sort_1(int a[])

{

int i,j,k,m,t;char str[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();

}

void sort()

{

int i,q;int mat[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");goto loot;}

else if (q==2){sort_1(c);printf("\t\t\t\n\n"); goto loot;}

else if (q==3){sort_1(su);printf("\t\t\t\n\n");goto loot;}

else if(q==4);

}

void seek_num()

{

char str[10];int i, 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输入的学号不存在");

}

void seek_name()

{

char str[10];int i, 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输入的姓名不存在");

}

void seek_1(int a[N])

{ int i,m,j=0,k;char e[50][50],b[50][50];int c[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();

}

void seek()

{

int i,q;int mat[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");goto looa;}

else if (q==2){seek_name();printf("\n\n");goto looa;}

else if (q==3){seek_1(mat);printf("\n\n");goto looa;}

else if(q==4){seek_1(c);printf("\n\n");goto looa;}

else if(q==5){seek_1(su);printf("\n\n");goto looa;}

else if (q==6);

}

void main()

{

int i,q;int mat[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");goto loop;

}

else if(q==2)

{

add();printf("\n\n");goto loop;

}

else if(q==3)

{

delet();printf("\n\n");goto loop;

}

else if(q==4)

{

sort();printf("\n\n");goto loop;

}

else if(q==5)

{

seek();printf("\n\n");goto loop;

}

else if(q==6)

{

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

}

}

㈥运行结果

原始界面

新建数据

添加数据

删除数据

成绩排序

成绩查询

退出界面

㈦分析与思考

C语言的确是一门很难学的课程。原本以为做个程序是件简单的事情,但是想错了。要完完整整把程序按照要求编出来是意见很不容易的事情。

从开始看题目,一个个分部分的分析、设计、写算法等等,真的是头疼啊!虽然有些地方可以套用书上或者知道书上的例题,但是一点点把程序拼接起来,一步步修改还是好艰难的啊。只能向同学求助,帮忙一起弄弄程序!所以元旦放假这几天经常去图书馆上个机,搞搞程序,把程序中的上百个错误一点点减少到零个,出现我们想要的操作界面。这个上交的程序是我们比较满意的,但还是有些地方还不够好。比如说数据编排还不够美观,虽然作了较多的努力,但是结果都不是很理想,最后还是放弃了,只能这样勉强看看。

这个程序下来,我觉得做程序需要很大的耐心,一个大点的程序有个几百甚至上千个步骤,没有耐心是做不成功的。当然细心也很需要,有很多错误都是自己的粗心造成的,有时甚至自己以遍遍检查都看不出来,还以为是什么大错误呢。但是即使是有一点点小错误,编的再怎么完美的程序也无法正常运行。所以编程序也是在锻炼一个人啊。

现在觉得我们学的东西还是比较少的,一个稍微大点的程序就把我们弄的这么痛苦,还是要多学点,多实践,才能真正掌握好。在以后的日子,要想把编程学好还是要下很大一番苦功夫的啊,所以要努力了啊!

本文来源:https://www.2haoxitong.net/k/doc/65c3586727d3240c8447efbc.html

《C语言 学生成绩管理系统实验报告.doc》
将本文的Word文档下载到电脑,方便收藏和打印
推荐度:
点击下载文档

文档为doc格式