叫我小墨迹吧 关注:11贴子:53
  • 1回复贴,共1

找数组最值 按如下函数原型编程从键盘输入一个m行n列的二维数

只看楼主收藏回复

找数组最值 按如下函数原型编程从键盘输入一个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);
找数组最值
按如下函数原型编程从键盘输入一个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);//函数返回最大值,pRow和pCol分别返回最大值所在的行列下标
例如,程序的1次运行结果如下:
Input n:
3,4↙
Input 3*4 array:
1 2 3 4↙
5 6 7 8↙
9 0 -1 -2↙
max=9,row=2,col=0
数组维数输入提示信息: "Input m,n:\n"
数组维数输入格式: "%d,%d"
数组元素输入提示信息: "Input %d*%d array:\n"
数组元素输入格式::"%d"
输出格式: "max=%d,row=%d,col=%d\n"
复制代码
#include <stdio.h>
void Input(int a[][10], int n,int m);
int Findmax(int a[][10], int n, int m,int *pos,int *col);
int main()
{
int n,m, a[30][10];
int maxNum;//存放数组最大值
int pRow;//存放最大值下标
int pcol;
printf("Input m,n:\n");
scanf("%d,%d",&n,&m);
getchar();
Input(a,n,m);
maxNum = Findmax(a,n,m,&pRow,&pcol);
printf("max=%d,row=%d,col=%d\n", maxNum, pRow,pcol);
return 0;
}
//读入数组元素的值
void Input(int a[][10], int n,int m)
{
int i,j;
printf("Input %d*%d array:\n",n,m);
for (i = 0; i < n; i++)
{
for(j=0;j<m;j++)
{
scanf("%d", &a[i][j]);
}
}
}
//计算数组最大值及最大值下标
int Findmax(int a[][10], int n,int m, int *pos,int *col)
{
int i,j ,maxNum;
*pos = 0;
*col=0;
maxNum = a[0][0];
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
if(a[i][j]>maxNum)
{
maxNum = a[i][j];
*pos = i;
*col= j;
}
}
}
return maxNum;
}
复制代码
--叫我小墨迹吧


来自Android客户端1楼2020-05-12 13:57回复
    C语言


    IP属地:北京来自Android客户端2楼2020-05-12 15:25
    回复