按如下函数原型编程从键盘输入一个m行n列的二维数组,然后计算数组中元素的最大值及其所在的行列下标值。其中,m和n的值由用户键盘输入。已知m和n的值都不超过10。
void InputArray(int p, int m, int n);
int FindMax(int *p, int m, int n, int *pRow, int *pCol);
输入提示信息:
"Input m, n:"
"Input %d%d array:\n"
输入格式:"%d,%d"
输出提示信息和格式:"max = %d, row = %d, col = %d\n"
#include
#define M 10
#define N 10
void InputMatrix(int p, int m, int n);
int FindMax(int *p, int m, int n, int *pRow, int *pCol);
int main()
{
int a[M][N], m, n, row, col, max;
printf("Input m, n:");
scanf("%d,%d", &m, &n);
InputMatrix(*a, m, n);
max = FindMax(*a, m, n, &row, &col);
printf("max = %d, row = %d, col = %d\n", max, row, col);
return 0;
}
/ 函数功能:输入m*n矩阵的值 /
void InputMatrix(int *p, int m, int n)
{
int i, j;
printf("Input %d%d array:\n", m, n);
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
scanf("%d", &p[i * n + j]);
}
}
}
/* 函数功能:在m*n矩阵中查找最大值及其所在的行列号 /
int FindMax(int *p, int m, int n, int *pRow, int *pCol)
{
int i, j, max = p[0];
*pRow = 0;
*pCol = 0;
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
if (p[i * n + j] > max)
{
max = p[i * n + j];
*pRow = i; /记录行下标*/
*pCol = j; /*记录列下标*/
}
}
}
return max;
}
那么这边小妹就看不懂了,在输入m*n矩阵的函数中在函数名中定义了一个指针变量p可以直接存储数组吗?指针不一般存储一个数的地址吗?可以存储一个数组的地址吗?
求大神赐教,小妹感激不尽
求大神帮帮忙,小妹感激不尽
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
悬赏问题
- ¥100 Jenkins自动化部署—悬赏100元
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条
- ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
- ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
- ¥15 perl MISA分析p3_in脚本出错
- ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
- ¥15 ubuntu虚拟机打包apk错误
- ¥199 rust编程架构设计的方案 有偿