当前位置: 代码迷 >> 综合 >> ZZULIOJ:1160: 矩阵的最大值(指针专题)
  详细解决方案

ZZULIOJ:1160: 矩阵的最大值(指针专题)

热度:44   发布时间:2023-12-05 08:23:33.0

1160: 矩阵的最大值(指针专题)

时间限制: 1 Sec  内存限制: 128 MB
[状态] [讨论版] [提交] [命题人:admin]

题目描述

找出一个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>
#include<string.h>void FindMax(int a[][3], int m, int n, int *pRow, int *pCol)
{int i, j, max, flag=0;max=a[0][0];for(i=0;i<m;i++){for(j=0;j<n;j++){if(a[i][j]>=max){max=a[i][j];}}}for(i=0;i<m;i++){for(j=0;j<n;j++){if(a[i][j]==max)//必须跳出,因为指针是指向i, j的,每循环一次,指针指向的i, j值都会变化{pRow=&i;pCol=&j;flag=1;break;}}if(flag==1)break;}printf("%d %d %d", max, *pRow, *pCol);
}
int main()
{int a[2][3], i, j;int *pRow=NULL;int *pCol=NULL;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;
}