1160: 矩阵的最大值(指针专题)
时间限制: 1 Sec 内存限制: 128 MB
提交: 331 解决: 586
[提交] [状态] [讨论版] [命题人:eilene]
题目描述
找出一个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
样例输出 Copy
100 0 0
#include<stdio.h>
void FindMax(int p[][3], int m, int n, int *pRow, int *pCol);
int main()
{
int s[2][3];
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
{
scanf("%d",*(s+i)+j);
}
}
int row,col;
FindMax(s,2,3,&row,&col);
return 0;
}
void FindMax(int p[][3], int m, int n, int *pRow, int *pCol)
{
int max;
max=p[0][0];
*pRow=0;
*pCol=0;
for(int i=0;i<m;i++)
{
for(int j=0;j<n;j++)
{
if(p[i][j]>max)
{
max=p[i][j];*pRow=i;*pCol=j;
}
}
}
printf("%d %d %d\n",max,*pRow,*pCol);
}