/*
* 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;
}