第十四周项目3-多科成绩单2

/*
 *Copyright(c)2014,烟台大学计算机学院
 *All rights reserved.
 *文件名称:test.cpp
 *作者:梁璨
 *完成日期:2014年 11月 27日
 *版本号:v1.0
 *
 *问题描述:某班不超过100名同学,用二维数组score[ ][4]保存同学们的高数、英语、C++成绩及总成绩(在此假设学生的学号为整形的连续值,用数组的行下标作学号)。在此基础上,完成相应的要求;
 *程序输入:输入学生人数、学生三科的成绩,学生姓名;
 *程序输出:输出各门课及总分的最高成绩、最低成绩、平均成绩和获得最高成绩的同学姓名;
 */



</pre><pre class="cpp" name="code">#include <iostream>

#include <string>

using namespace std;

void input(double s[][4],int n);

void input(string name[],int n);

void output(double s[][4],int n);

double max(double s[][4],int n,int i);

double min(double s[][4],int n,int i);

double avg(double s[][4],int n,int i);

int main()
{
    int i,j,num;
    string temp;
    double score[100][4];
    string name[100],course[4]= {"高等数学","英语","C++","总分"};
    cout<<"输入学生人数:";
    cin>>num;
    cout<<"请输入学生名字:";
    input(name,num);
    input(score,num);
    output(score,num);
    for(i=0; i<4; i++)
    {
        cout<<course[i]<<"的最高成绩是"<<max(score,num,i)<<",";
        cout<<"最低成绩是"<<min(score,num,i)<<",";
        cout<<"平均成绩是"<<avg(score,num,i)<<",";
        for(j=0; j<num; j++)
        {
            if(score[j][i]==max(score,num,i))
                cout<<"获得最高成绩同学的名单:"<<name[j]<<" ";
        }
        cout<<endl;
    }
    return 0;
}
void input(double s[][4],int n)
{
    int i,j;
    for(i=0,s[i][3]=0; i<n; i++)
    {
        cout<<"第"<<i+1<<"位同学的成绩:";
        for(j=0; j<3; j++)
        {
            cin>>s[i][j];
            s[i][3]+=s[i][j];
        }
    }
}
void input(string name[],int n)
{
    int i;
    for(i=0; i<n; i++)
    {
        cin>>name[i];
    }
}
void output(double s[][4],int n)
{
    int i;
    for(i=0; i<n; i++)
    {
        cout<<"第"<<i<<"同学的成绩为:高等数学:"<<s[i][0]<<" "<<"英语:"<<
            s[i][1]<<" "<<"C++:"<<s[i][2]<<" "<<"总分:"<<s[i][3]<<" "<<endl;
    }
}
double max(double s[][4],int n,int i)
{
    int j;
    double max;
    max=0;
    for(j=0; j<n; j++)
    {
        if(s[j][i]>max)
            max=s[j][i];
    }
    return max;
}
double  min(double s[][4],int n,int i)
{
    int j;
    double min;
    min=10000;
    for(j=0; j<n; j++)
    {
        if(s[j][i]<min)
            min=s[j][i];
    }
    return min;
}
double avg(double s[][4],int n,int i)
{
    int j;
    double avg,sum=0;
    for(j=0; j<n; j++)
    {
        sum+=s[j][i];
    }
    avg=sum/n;
    return avg;
}

运行结果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值