第十四周-成绩处理

/*
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 作者:刘慧艳
* 完成日期: 2013年12月1日
* 版本号: v1.0
* 输入描述: 使用输入重定向,input。txt{110 23 56 99 87 2 0 59 63 47}
* 问题描述: (1)输入小组人数及成绩,要保证成绩在0‐100 之间;
             (2)输出该小组的最高成绩、最低成绩、平均成绩;
             (3)输出考得最高成绩和最低成绩的同学的人数;
             (4)输出考得最高成绩和最低成绩的同学的学号.
*/

#include <iostream>
#include <cstdio>
using namespace std;
int main()
{
    int size=50;
    int a[size],i,num,max=0,min=100,sum=0,ave,j=0,k=0;
    cout<<"小组共有多少位同学:"<<endl;
    cin>>num;
    cout<<"请输入学生成绩"<<endl;
    freopen("input.txt","r",stdin);
    for(i=0; i<num; ++i)
    {
        cout<<"\n请输入第"<<i<<"名同学的成绩:\t";
        cin>>a[i];
        if(a[i]<0||a[i]>100)
        {
            cout<<"\n请重新输入第"<<i<<"名同学的成绩:\t";
            cin>>a[i];
        }
    }

    for(i=0; i<num; ++i)
    {
        if(a[i]>max)
            max=a[i];
        if(a[i]<min)
            min=a[i];
        sum=sum+a[i];
    }
    ave=sum/num;
    cout<<"\n最高成绩为:"<<max<<"\t";
    cout<<"最低成绩为:"<<min<<"\t";
    cout<<"平均成绩为:"<<ave<<"\t";
    for(i=0; i<num; ++i)
    {
        if(a[i]==max)++j;
    }
    cout<<"\n取得最高成绩"<<max<<"的有"<<j<<"人,他们的学号是:";
    for(i=0; i<num; ++i)
    {
        if(a[i]==max)cout<<i<<"\t";
    }
    for(i=0; i<num; ++i)
    {
        if(a[i]==min)++k;
    }
    cout<<"\n取得最低成绩"<<min<<"的有"<<k<<"人,他们的学号是:";
    for(i=0; i<num; ++i)
    {
        if(a[i]==min)cout<<i<<"\t";
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值