1160: 矩阵的最大值(指针专题)
时间限制: 1 Sec 内存限制: 128 MB
找出一个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个整数,矩阵中的最大值及其行下标和列下标,数据之间用空格隔开。测试数据保证最大值唯一。
样例输入 Copy
100 3 6 0 87 65
#include<stdio.h>
void FindMax(int p[2][3], int m, int n, int* pRow, int* pCol)
{
int x, y,t=0, r=0; //t,r用于更新最大值对应的下标
int max = p[0][0];
for (x = 0; x < m; x++)
{
for (y = 0; y < n; y++)
{
if (p[x][y] > max)
{
max = p[x][y];
t = x, r = y;
}
}
}
printf("%d %d %d", p[t][r], t, r);
}
int main()
{
int arr[2][3];
int m,n;
int x, y,*pRow=&x,*pCol=&y;
for (m = 0; m < 2; m++)
{
for (n = 0; n < 3; n++)
{
scanf("%d", &arr[m][n]);
}
}
FindMax(arr, m, n, pRow, pCol);
return 0;
}