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

1160: 矩阵的最大值(指针专题)
时间限制: 1 Sec 内存限制: 128 MB
提交: 6136 解决: 4171
[状态] [讨论版] [提交] [命题人: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>

// 函数原型声明 
void FindMax(int p[][3], int m, int n, int *pRow, int *pCol);

int main() {
    
    
	int p[2][3];
	int m = 2, n = 3;
	int *pRow, *pCol;
	int i, j;
	// 输入2行3列整数 
	for(i = 0; i < m; i++)
		for(j = 0; j < n; j++)
			scanf("%d", &p[i][j]);
	
	// 调用函数FindMax输出数组最大值及其下标
	FindMax(p, m, n, pRow, pCol); 
	return 0;
}

// 函数输出矩阵的最大值及其下标 
void FindMax(int p[][3], int m, int n, int *pRow, int *pCol){
    
    
	int i, j;
	int t, k, max = 0;
	for(i = 0; i < m; i++){
    
    
		for(j = 0; j < n; j++){
    
    
			// 求最大值 
			if(max < p[i][j]){
    
    
				max = p[i][j];
				t = i;
				k = j;
			}
		}
	}
	// 两个指针分别指向最大值的行下标和列下标的内存地址 
	pRow = &t, pCol = &k; 
	// 输出最大值及其行下标和列下标
	printf("%d %d %d", max, *pRow, *pCol); 
}

おすすめ

転載: blog.csdn.net/m0_45306379/article/details/121756604