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

题目描述

找出一个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 <iostream>
using namespace std;
int p[2][3];
void FindMax(int p[][3], int m, int n, int *pRow, int *pCol)
{
    int maxnum = -1e9;
    for(int i = 0;i < m;i ++ )
    {
        for(int j = 0;j < n;j ++ )
        {
            maxnum = max(maxnum,p[i][j]);
        }
    } 
    for(int i = 0;i < m;i ++ )
    {
        for(int j = 0;j < n;j ++ )
        {
            if(p[i][j] == maxnum)
            {
                *pRow = i;
                *pCol = j;
            }
        }
    }
}
int main()
{
    int x,y;
    for(int i = 0;i < 2;i ++ )
    {
        for(int j = 0;j < 3;j ++ )
        {
            cin >> p[i][j];
        }
    }    
    FindMax(p,2,3,&x,&y);
    cout << p[x][y] << ' ' << x << ' ' << y << endl;
    return 0;
}

猜你喜欢

转载自blog.csdn.net/couchpotatoshy/article/details/126078529
今日推荐