1

我被赋予了一项任务,这没什么特别的,但我确实在这里碰壁了...

获得算术手段后,我需要比较它们并输出最高和最低的。

x 是学生编号,vid[] 是算术平均值。

例如:

学生编号 x 具有算术平均值 vid[i]

任务要我输出哪个学生的收入最高,哪个学生的收入最低。

最糟糕的是我不能使用 max() 和 min() 之类的东西,因为我不知道总共有多少学生。另外,它们都是具有相同变量名称 vid[] 的数组。

任何帮助将不胜感激 =)

int main()
{
    int mokSK=0, p1[25], p2[25], p3[25], x[25], vid[25], iv=0;
    ifstream inFile("inFile.in");
    ofstream outFile("outFile.out");


    inFile >> mokSK;

    for(int i=0;i<mokSK;i++)
    {
        inFile >> x[i] >> p1[i] >> p2[i] >> p3[i];
        vid[i]=(p1[i]+p2[i]+p3[i])/3;
        outFile<< x[i] <<" " << vid[i] << endl;
    }

    return 0;
}
4

2 回答 2

5

如果您希望 O(1) 访问最大和最小评分的学生;从阅读开始,在每次阅读过程中更新您的最高和最低评分学生。

更清楚一点:从执行一开始就跟踪最小和最大评分学生,并在需要时更新每个学生数据阅读通道中的最大和最小评分学生。

于 2011-11-12T13:10:31.703 回答
-1
int main()
{
  int mokSK=0, p1[25], p2[25], p3[25],x[25],vid[25],iv=0;
  int minmean = INT_MAX; int minstud= 0;// initialize minmean and max mean with first mean
  int maxmean = 0; int maxstud= 0;
  ifstream inFile("inFile.in");
  ofstream outFile("outFile.out");
  inFile >> mokSK;
  for(int i=0;i<mokSK;i++)
  {
    inFile >> x[i] >> p1[i] >> p2[i] >> p3[i];
    vid[i]=(p1[i]+p2[i]+p3[i])/3;
    if(vid[i]>maxmean){maxmean = vid[i]; maxstud = i;}
    if(vid[i]<minmean){minmean = vid[i]; minstud = i;}
    // not handled if multple students have maxmean or minmean
    outFile<< x[i] <<" " << vid[i] << endl; 
  }

 outFile << "Max mean: " << maxmean << ", student id: " << maxstud << endl;
 outFile << "Min mean: " << minmean << ", student id: " << minstud << endl;
 return 0;
}
于 2011-11-12T13:34:17.537 回答