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

时间:2024.4.20

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

㈠实验名称:

学生成绩管理系统

㈡实验目的:

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

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

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

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

S1:输入要删除的学生学号m
S2:0->i,0->j
S3:若学生的学号stu[i].num,转到S6,否则继续
S4:i+1->i
S5:若i<n,返回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<n,返回S7,否则继续

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

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

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

S1:0->i

S2:i+1->j

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

S4:j+1->j

S5:若j<n,n为学生原有人数,返回S3

S6:i+1->i

S7:若i<n-1,返回S2

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

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

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

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

S2:0->i

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

S4:i+1->i

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

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

S1:输入最低分数线m

S2:0->i,0->j

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

S4:i+1->i

S5:若i<n,返回S3

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<j,返回S9,否则算法结束

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

㈤程序清单

#include<string.h>

#include<stdio.h>

# 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<n;i++)

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

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

 for(i=0;i<n;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<n;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<n;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<n;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<n-1;i++)

    for(j=i+1;j<n;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[i].C=stu[j].C;stu[j].C=t;

        }

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

            for(i=0;i<n;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<n;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<n;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<n;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<n;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<j;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<n;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<n;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语言的确是一门很难学的课程。原本以为做个程序是件简单的事情,但是想错了。要完完整整把程序按照要求编出来是意见很不容易的事情。

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

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

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

更多相关推荐:
java学生成绩管理系统实验报告

JAVA课内实验报告学生成绩管理系统一实验目的及实验环境实验目的在如今的高校日常管理当中学生成绩管理系统就是其中非常重要的一环特别是当前学生规模大课程门类多校区分散等实际情况学生成绩管理系统更具有非常大的实际应...

学生信息管理系统实验报告

西安郵電學院数据库原理及应用设计报告题目:学生信息管理系统一.设计目的学生管理系统是高校管理工作中一项非常重要的组成部分。用户的需求具体体现在各种信息的提供、保存、更新和查询方面,这就要求数据库结构能充分满足各…

学生成绩管理系统C++编程实验报告

C程序设计课程设计报告设计题目学生成绩管理系统专业计算机科学与技术网络工程班级学号姓名指导老师日期20xx0531目录一设计任务与要求31设计内容32课程设计的要求3二系统分析需求分析31需求分析32系统性能要...

学生成绩管理系统课程设计报告

1目录1需求与功能分析32系统总体框架43模块设计与分析44类的设计与分析65特色算法分析76功能测试107存在的不足与对策138程序源代码149使用说明2310参考文献2321需求与功能分析1需求分析学生成绩...

学生成绩管理系统--课程设计报告

数据结构课程设计报告课题名称姓名学院系科班级指导老师日期学生成绩管理系统20xx年1月17日目录一问题描述3二基本要求3三设计目的4四概念设计4五详细设计51主要数据结构52模块功能53调用关系5六源程序5七测...

学生成绩管理系统数据库设计实验报告

学生成绩管理系统数据库课题雇员信息管理系统姓名学号同组姓名专业班级指导教师设计时间20xx年6月4号20xx年6月10日一需求分析阶段1信息需求对学校而言学生成绩管理系统是所有工作的首要之选但是高校学生的成绩管...

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

学生成绩管理系统C语言程序设计实训报告姓名专业班级指导教师20xx年7月14日目录一实训目的和要求1二实训任务内容1三详细设计说明1四软件使用说明2五实训心得与体会6参考文献7附录部分程序清单7I一实训目的和要...

数据库综合实验报告(学生成绩管理系统)

数据库综合实验报告班级:计科***班学号:****姓名:***20XX年12月数据库应用系统的初步开发一、实验类别:综合型实验二、实验目的1.掌握数据库设计的基本技术,熟悉数据库设计的每个步骤中的任务和实施方案…

C#学生成绩管理系统课程设计报告

C程序设计课程设计报告2020学年第学期题目学生成绩信息管理系统专业班级姓名学号指导教师成绩年月日目录摘要1第一章绪论211设计目的212开发工具选择213开发环境214本报告的主要内容2第二章需求分析321系...

C语言程序设计学生成绩管理系统实验报告

移通学院C语言程序设计报告书设计名称学生成绩管理系统专业指导老师班级姓名学号座号时间一实验目的1在编辑应用程序过程中逐步加深对C语言编程的理解2加强实践的能力动手能力同时进一步对所学的知识进行巩固3培养初步编程...

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

高级语言程序设计课程设计实验报告题目学生成绩管理系统专业班级姓名成绩指导教师完成日期20xx年06月24日一目的1进一步掌握和利用C语言进行程设计的能力2进一步理解和运用结构化程设计的思想和方法3初步掌握开发一...

php学生成绩管理系统设计报告

JINGCHUUNIVERSITYOFTECHNOLOGYPHP学生成绩管理系统学院计算机工程学院学号20xx304030223学生姓名朱钟雄年级专业12计算机应用技术班级计算机应用技术2班指导教师沈成涛日期2...

学生成绩管理系统实验报告(31篇)