Description
找出一个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所指内存单元
}
Input
输入2行3列整数,共6个。
Output
输出3个整数,矩阵中的最大值及其行下标和列下标,数据之间用空格隔开。测试数据保证最大值唯一。
Sample Input
100 3 60 87 65
Sample Output
100 0 0
HINT
Source
#include <stdio.h>
#include <stdlib.h>
//在m*n矩阵p中查找最大值,将其行下标存入pRow所指内存单元,将其列下标存入pCol所指内存单元
void FindMax(int p[][3], int m, int n, int *pRow, int *pCol)
{
int max=0,i,j;
for(i=0; i<m; i++)
for(j=0; j<n; j++)
{
if(p[i][j]>=max)
max=p[i][j];
}
int flag=0;
for(i=0; i<m; i++)
{
for(j=0; j<n; j++)
{
if(p[i][j]==max)
{
pRow=&i;
pCol=&j;
flag=1;
break;
}
}
if(flag==1)
break;
}
printf("%d %d %d\n",max,*pRow,*pCol);
}
int main()
{
int a[2][3];
int i,j;
int *prow=0,*pcol=0;
for(i=0; i<2; i++)
{
for(j=0; j<3; j++)
{
scanf("%d",&a[i][j]);
}
}
FindMax(a,2,3,prow,pcol);
return 0;
}