首页 > 其他分享 >学生成绩管理系统(实验四)

学生成绩管理系统(实验四)

时间:2022-11-12 20:34:53浏览次数:51  
标签:num 管理系统 int sum long score 实验 printf 成绩

/*1.学生成绩管理系统V1.0
某班有最多不超过40人(具体人数由键盘输入)参加某门课程的考试,用数组作函数参数编程实现如下学生成绩管理:
(1)录入每个学生的学号和考试成绩;
(2)计算课程的总分和平均分;
(3)按成绩由高到低排出名次表;
(4)按学号由小到大排出成绩表;
(5)按学号查询学生排名及其考试成绩;
(6)按优秀(90-100)、良好(80-89)、中等(70-79)、及格(60-69)、不及格(0-59)5个类别,统计每个类别的人数以及所占的百分比;
(7)输出每个学生的学号、考试成绩,课程总分和平均分。
2.学生成绩管理系统V1.1
在学生成绩管理系统V1.0的基础上,要求程序运行后先显示如下菜单,并提示用户输入选项:
(1)Append record
(2)Calculate total and average score of course
(3)Sort in descending order by score
(4)Sort in ascending order by number
(5)Search by number
(6)Statistic analysis
(7)List record
(8)Exit
*/

1.0

#include <stdio.h>
#include <stdlib.h>
#define N 40
int Menu();
int ReadScore(int score[],long num[]);
int calculate(int score[],int n);
int ScoreSort(int score[],long num[],int n);
void printScore(int score[],long num[],int n);
int SearchScore(int score[],long num[],int n);

int main()
{
    int score[N],n,sum,i,a=0,b=0,c=0,d=0,e=0,s;
    long num[N];
    n=ReadScore(score,num);
    sum=calculate(score,n);
    printf("Calculate total and average score of course:\n");
    printf("sum=%d,ave=%d\n",sum,sum/n);
    printf("Sort in ascending order by number:\n");
    printScore(score,num,n);
    ScoreSort(score,num,n);
    printf("Sort in descending order by score:\n");
    printScore(score,num,n);
    SearchScore(score,num,n);
    for(i=0;i<n;i++)
    {
        if(score[i]>=90 && score[i]<=100)
            a++;
        if(score[i]>=80 && score[i]<90)
            b++;
        if(score[i]>=70 && score[i]<80)
            c++;
        if(score[i]>=60 && score[i]<70)
            d++;
        if(score[i]>=0 && score[i]<60)
            e++;
    }
    printf("Statistic analysis\n");
    printf("优秀(90-100)=%d\n良好(80-89)=%d\n中等(70-79)=%d\n及格(60-69)=%d\n不及格(0-59)=%d\n",a,b,c,d,e);
    printf("优秀(90-100)=%d\n良好(80-89)=%d\n中等(70-79)=%d\n及格(60-69)=%d\n不及格(0-59)=%d\n",a/n,b/n,c/n,d/n,e/n);
    return 0;
}

int ReadScore(int score[],long num[])
{
    int i=20221401,n;
    for(n=0;n<N;n++)
    {
        scanf("%d",&score[n]);
        if(score[n]<0)
            return n;
        num[n]=i;
        i++;
    }
    return n;
}

int calculate(int score[],int n)
{
    int i,sum;
    sum=0;
    for(i=0;i<n;i++)
    {
        sum+=score[i];
    }
    return sum;
}

int ScoreSort(int score[],long num[],int n)
{
    int a,b,c,temp1;
    long temp2;
    for(a=0;a<n-1;a++)
    {
        c=a;
        for(b=a+1;b<n;b++)
        {
            if(score[b]>score[c])
            {
                c=b;
            }
        }
        if(c!=a)
        {
            temp1=score[c];
            score[c]=score[a];
            score[a]=temp1;
            temp2=num[c];
            num[c]=num[a];
            num[a]=temp2;
        }
    }
}

void printScore(int score[],long num[],int n)
{
    int i;
    for(i=0;i<n;i++)
    {
        printf("%10ld%4d\n",num[i],score[i]);
    }
}

SearchScore(int score[],long num[],int n)
{
    int m;
    long i;
    printf("Search by number:");
    scanf("%ld",&i);
    for(m=0;m<=n;m++)
    {
        if(i==num[m])
        {
            printf("%d\n",score[m]);
        }
    }
}

2.0

#include <stdio.h>
#include <stdlib.h>
#define N 40
#define M 20221401
int Menu();
int ReadScore(int score[],long num[]);
int calculate(int score[],int n);
int ScoreSort(int score[],long num[],int n);
int NumSort(int score[],long num[],int n);
int printScore(int score[],long num[],int n);
int SearchScore(int score[],long num[],int n);
int Analysis(int score[],long num[],int n);
int main()
{
    int score[N],n,sum;
    char select;
    long num[N];
    while(1)
    {
        select = Menu();
        switch(select)
        {
        case 1:
            n=ReadScore(score,num);
            break;
        case 2:
            sum=calculate(score,n);
            break;
        case 3:
            ScoreSort(score,num,n);
            break;
        case 4:
            NumSort(score,num,n);
            break;
        case 5:
            SearchScore(score,num,n);
            break;
        case 6:
            Analysis(score,num,n);
            break;
        case 7:
            printScore(score,num,n);
            sum=calculate(score,n);
            printf("Calculate total and average score of course:\n");
            printf("sum=%d,ave=%d\n",sum,sum/n);
            break;
        case 8:
            printf("End");
            exit(0);
        default:
            printf("Error!");
        }
    }
}
int Menu()
{
    int select;
    printf("Management System for Students' scores\n");
    printf("1.Input record\n");
    printf("2.Caculate total and average score of course\n");
    printf("3.Sort in descending order by score\n");
    printf("4.Sort in ascending order by number\n");
    printf("5.Search by number\n");
    printf("6.Statistic analysis\n");
    printf("7.List record\n");
    printf("8.Exit\n");
    printf("Please Input your choice:\n");
    scanf("%d",&select);
    return select;
}

int ReadScore(int score[],long num[])
{
    int n;
    long i=M;
    for(n=0; n<N; n++)
    {
        scanf("%d",&score[n]);
        if(score[n]<0)
            return n;
        num[n]=i;
        i++;
    }
    return n;
}

int calculate(int score[],int n)
{
    int i,sum;
    sum=0;
    for(i=0; i<n; i++)
    {
        sum+=score[i];
    }
    return sum;
}

int ScoreSort(int score[],long num[],int n)
{
    int a,b,c,temp1;
    long temp2;
    for(a=0; a<n-1; a++)
    {
        c=a;
        for(b=a+1; b<n; b++)
        {
            if(score[b]>score[c])
            {
                c=b;
            }
        }
        if(c!=a)
        {
            temp1=score[c];
            score[c]=score[a];
            score[a]=temp1;

            temp2=num[c];
            num[c]=num[a];
            num[a]=temp2;
        }
    }
}

int NumSort(int score[],long num[],int n)
{
    int a,b,c,temp1;
    long temp2;
    for(a=0;a<n;a++)
    {
        c=a;
        for(b=a+1;b<n;b++)
        {
            if(num[b]<num[c])
            {
                c=b;
            }
        }
        if(c!=a)
        {
            temp1=score[c];
            score[c]=score[a];
            score[a]=temp1;

            temp2=num[c];
            num[c]=num[a];
            num[a]=temp2;
        }
    }
}

int printScore(int score[],long num[],int n)
{
    int i;
    for(i=0; i<n; i++)
    {
        printf("%10ld%4d\n",num[i],score[i]);
    }
}

int SearchScore(int score[],long num[],int n)
{
    int m;
    long i;
    printf("Search by number:");
    scanf("%ld",&i);
    for(m=0; m<=n; m++)
    {
        if(i==num[m])
        {
            printf("%d\n",score[m]);
            return 0;
        }
    }
    printf("Not Found!");
}

int Analysis(int score[],long num[],int n)
{
    int i;
    float a=0,b=0,c=0,d=0,e=0;
    for(i=0; i<n; i++)
    {
        if(score[i]>=90 && score[i]<=100)
            a++;
        if(score[i]>=80 && score[i]<90)
            b++;
        if(score[i]>=70 && score[i]<80)
            c++;
        if(score[i]>=60 && score[i]<70)
            d++;
        if(score[i]>=0 && score[i]<60)
            e++;
    }
    printf("Statistic analysis\n");
    printf("优秀(90-100)=%d\n良好(80-89)=%d\n中等(70-79)=%d\n及格(60-69)=%d\n不及格(0-59)=%d\n",a,b,c,d,e);
    printf("优秀(90-100)=%f\n良好(80-89)=%f\n中等(70-79)=%f\n及格(60-69)=%f\n不及格(0-59)=%f\n",a/n,b/n,c/n,d/n,e/n);
}

标签:num,管理系统,int,sum,long,score,实验,printf,成绩
From: https://www.cnblogs.com/20031004wzy/p/16884571.html

相关文章

  • 结对实验二
    (1)本人角色本人在在这次实验结对项目中所担任领航员我的结对伙伴是梁添翔,学号:223201062132(2)本次的程序任务和要求如上图所示,需要有4部电梯同时运行,每部电梯都有自己的限制且......
  • 实验三:朴素贝叶斯算法实验
    【实验目的】理解朴素贝叶斯算法原理,掌握朴素贝叶斯算法框架。【实验内容】针对下表中的数据,编写python程序实现朴素贝叶斯算法(不使用sklearn包),对输入数据进行预测;熟悉s......
  • 实验二结对编程
    1实验内容及要求 1.1 教学内容及要求完成结对项目,实现代码复审。1.2 实验要求首先在同学中找一个同伴,范围不限,可以在1~3班中随意组合,不要找同组的成员,女同学尽量......
  • 实验三:朴素贝叶斯算法实验
    【实验目的】理解朴素贝叶斯算法原理,掌握朴素贝叶斯算法框架。【实验内容】针对下表中的数据,编写python程序实现朴素贝叶斯算法(不使用sklearn包),对输入数据进行预测;熟悉s......
  • 使用JFinal实现简单的学生管理系统
    JFinal简介Controller是JFinal核按心类美之一,该类作为MVC模式中的控制器。基于JFinal的Web应用的控制器需要继承该类。Controller是定义Action方法的地点,是组织Action的一......
  • 实验三:朴素贝叶斯算法实验
    |20大数据三班| 20大数据三班 ||----|----|----||作业要求|作业要求||学号|20161337|实验三:朴素贝叶斯算法实验【实验目的】理解朴素贝叶斯算法原理,掌握......
  • 实验7:基于REST API的SDN北向应用实践
    一、实验目的1、能够编写程序调用OpenDaylightRESTAPI实现特定网络功能;2、能够编写程序调用RyuRESTAPI实现特定网络功能。二、实验环境1、下载虚拟机软件OracleVi......
  • 实验7:基于REST API的SDN北向应用实践s
    实验7:基于RESTAPI的SDN北向应用实践一、实验目的1.能够编写程序调用OpenDaylightRESTAPI实现特定网络功能;2.能够编写程序调用RyuRESTAPI实现特定网络功能。二、实......
  • 实验7:基于REST API的SDN北向应用实践
    实验7:基于RESTAPI的SDN北向应用实践一、实验目的能够编写程序调用OpenDaylightRESTAPI实现特定网络功能;能够编写程序调用RyuRESTAPI实现特定网络功能。二、实验环......
  • 软件工程实验二 结对编程
    一、题目要求我们在刚开始上课的时候介绍过一个小学四则运算自动生成程序的例子,请实现它,要求:(1)能够自动生成四则运算练习题(2)可以定制题目数量(3)用户可以选择运算符(4)用户设置......