第14周项目3 项目 3-多科成绩单(1)(2)

问题描述:

 某班不超过 100名同学。用二维数组 score[][4]保存同学们的高数、英语、C++成绩及总成绩(在
此假设学生的学号为整型的连续值,用数组的行下标作学号)。在此基础上,完成下面的操作:
(1)输入学生的实际人数 num,在输入各科的成绩时,输入 3 科成绩后可以自动求出总分,并
将数据全保存到数组中;

(2)输出各门课及总分的最高成绩、最低成绩、平均成绩 。

代码:

#include<iostream>
#include<string>
using namespace std;
void input(double s[][4],int n); //输入成绩
void output(double s[][4],int n); //输出成绩
double max(double s[][4],int n,int i); //求第 i门课的最高成绩,i=3 时是总分
double min(double s[][4],int n,int i); //求第 i门课的最低成绩
double avg(double s[][4],int n,int i); //求第 i门课的平均成绩
int main()
{
    int i,num;
    string temp;
    double score[100][4]; //设一个班最多 100人,实际按输入来
    string course[4]= {"高等数学","英语","C++","总分"};
    cout<<"输入学生人数:";
    cin>>num;
//(1)输入成绩并求出总分
    input(score,num);
//(2)输出成绩
    output(score,num);
//(3)输出各门课及总分的最高成绩、最低成绩、平均成绩和成绩的标准偏差;
    for(i=0; i<4; ++i)
    {
        cout<<course[i]<<"的最高成绩是"<<max(score,num,i)<<", ";
        cout<<"最低成绩是"<<min(score,num,i)<<", ";
        cout<<"平均成绩是"<<avg(score,num,i)<<", ";
        cout<<endl;
    }
    return 0;
}
void input(double s[][4],int n) //输入成绩
{
    int i,j,t=0;
    i=0;
    while (i<n)
    {
        j=0,t=0;
        cout<<"请输入学号为"<<i<<"同学的成绩"<<'\n';
        while(j<3)
        {
            cin>>s[i][j];
            t+=s[i][j];
            j++;
        }
        s[i][3]=t;
        i++;
    }
}
void output(double s[][4],int n) //输出成绩
{
   int i,j;
   i=0;
   while (i<n)
   {
       cout<<"学号为"<<i<<"的同学的各科成绩为:";
       j=0;
       while (j<3)
        cout<<s[i][j++]<<'\t';
        cout<<"总成绩为:"<<s[i][j]<<'\n';
       i++;
   }
}
double max(double s[][4],int n,int i)  //求第 i门课的最高成绩,i=3 时是总分
{
    double m=-1;
    int j=0;
    while(j<n)
    {
        if(s[j][i]>m)
            m=s[j][i];
        j++;
    }
    return m;
}
double min(double s[][4],int n,int i)  //求第 i门课的最低成绩
{
    double m=10000;
    int j=0;
    while(j<n)
    {
        if(s[j][i]<m)
            m=s[j][i];
        j++;
    }
    return m;
}
double avg(double s[][4],int n,int i)  //求第 i门课的平均成绩
{
    double pj=0;
    int j=0;
    while (j<n)
        pj+=s[j++][i];
    pj/=n;
    return pj;
}

运行结果:



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值