【问题描述】
m*n的二维数组存放学生的成绩,每行是一个学生的成绩,每个学生均有n个科目。编写函数record,以二维数组作为形参,录入学生的成绩,函数返回类型为void。然后,编写函数highest,以指向一维数组的指针作为参数,找到不分科目的成绩中(所有分数中),最高的那个,需要传出学生所在数组元素的行、列下标,函数返回类型为void。假设学生最多不超过40个。学生分数的double型,学生个数在main函数里面通过用户输入获得。输入中,每个学生的成绩用一行表示,分数之间用空格分隔。成绩的取值区间为[0,100]。这里假设有4科成绩。(为了节省时间,在测试的时候,可以把学生人数取较小的值,科目数设置为较小的值;测试通过后再修改为要求的值。)
【输入形式】
3
67.5 77.5 72.5 88.2
47.5 67.4 82.3 85.4
87.5 37.5 62.8 81.2
【输出形式】
Number of students:
Please input scores of students:
hightest:
0 3
#include<bits/stdc++.h>
using namespace std;
void record(int m,double arr[][4]){//录入成绩
for(int i=0;i<m;i++){
for(int j=0;j<4;j++){
cin>>arr[i][j];
}
}
}
void highest(double (*p)[4],int m){
int MAX=p[0][0];
int max_i=0,max_j=0;
for(int i=0;i<m;i++){
for(int j=0;j<4;j++){
if(MAX<*(*(p+i)+j)){
MAX=*(*(p+i)+j);
max_i=i;
max_j=j;
}
}
}cout<<max_i<<" "<<max_j;
}
int main(){
int m=0;
double arr[40][4];
cout<<"Number of students:\n";
cin>>m;
cout<<"Please input scores of students:\n";
record(m,arr);
cout<<"hightest:\n";
highest(arr,m);
}