https://iuwe.cc/index.php/archives/80/
找数组最值 按如下函数原型编程从键盘输入一个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; }