找出一个2×3的整数矩阵中的最大值及其行下标和列下标,要求调用函数FindMax(int p[][3], int m, int n, int *pRow, int *pCol)实现,行下标和列下标在形参中以指针的形式返回。
void FindMax(int p[][3], int m, int n, int *pRow, int *pCol){
//在m*n矩阵p中查找最大值,将其行下标存入pRow所指内存单元,将其列下标存入pCol所指内存单元
}
输入2行3列整数,共6个。
输出输出3个整数,矩阵中的最大值及其行下标和列下标,数据之间用空格隔开。测试数据保证最大值唯一。
100 3 6 0 87 65样例输出 Copy
100 0 0
#include <stdio.h> #include <stdlib.h> #include <limits.h> void FindMax(int p[][3], int m, int n, int *pRow, int *pCol); int main() { int a[2][3],m,n,i,j; for(i=0;i<2;i++) for(j=0;j<3;j++) { scanf("%d",&a[i][j]); } FindMax(a,m,n,&m,&n); return 0; } void FindMax(int p[][3], int m, int n, int *pRow, int *pCol) { int max=INT_MIN,i,j; for(i=0;i<2;i++) for(j=0;j<3;j++) { if(p[i][j]>max) { max=p [i][j]; m=i; n=j; } } *pRow=m; *pCol=n; printf("%d %d %d\n",max,*pRow,*pCol); }