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

1160: 矩阵的最大值(指针专题)
时间限制: 1 Sec 内存限制: 128 MB
提交: 4287 解决: 2914
[状态] [讨论版] [提交] [命题人: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>
int FindMax(int p[][3],int m,int n,int *pRow,int *pCol)
{
	int i,j,max;
	max=p[0][0];
	for(i=0;i<m;i++)
	{
		for(j=0;j<n;j++)
		{
			if(p[i][j]>max)//找出最大值,并且把其行列分别
				           //赋值给pRow指向的i的和pCol指的j
			{
				max=p[i][j];
				*pRow=i;
	            *pCol=j;
			}
		}
	}
	return(max);
}
int main()
{
	int FindMax(int p[][3],int m,int n,int *pRow,int *pCol);
	int a[2][3];
	int i,j,max;
	int *pr,*pc;
	for(i=0;i<2;i++)
	{
		for(j=0;j<3;j++)
			scanf("%d",&a[i][j]);
	}
	pr=&i;pc=&j;
	max=FindMax(a,2,3,pr,pc);
	printf("%d %d %d\n",max,*pr,*pc);
	return 0;
}
发布了48 篇原创文章 · 获赞 0 · 访问量 451

猜你喜欢

转载自blog.csdn.net/YGGZZZ/article/details/104782686