0
点赞
收藏
分享

微信扫一扫

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

眸晓 2022-01-09 阅读 53

找出一个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 i,j,max,k=0;
    max=p[0][0];
    for(i=0;i<m;i++)
    {
        for(j=0;j<n;j++)
        {
            if(p[i][j]>max)
            {
                max=p[i][j];
            } 
        }
    }
    for(i=0;i<m;i++)
    {
        for(j=0;j<n;j++)
        {
            if(p[i][j]==max)
            {
                pRow=&i;
                pCol=&j;
                k=1;
                break;
            }
        }
        if(k==1) break;
    }
    printf("%d %d %d",max,*pRow,*pCol);
}
int main()
{
    int p[2][3],i,j;
    int *pRow,*pCol;
    for(i=0;i<2;i++)
    {
        for(j=0;j<3;j++)
        {
            scanf("%d",&p[i][j]);
        }     
    }
    FindMax(p,2,3,pRow,pCol);
    return 0;
} 



举报

相关推荐

0 条评论