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

来源:互联网 发布:大数据开发难学吗 编辑:程序博客网 时间:2024/05/29 16:45

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;}