任务描述
编程输出一个整型二维数组的高。二维数组的高定义为:最大元素与最小元素的差。
输入格式:
首先是两个正整数M,N(0
输出格式:
输出此数组的高。
输入样例:
3 5
12 25 56 89 -98
100 200 210 300 2
55 88 66 77 44
输出样例:
398
#include
int main(){
int m,n,i,j,max=0,min=0,ans=0;
scanf("%d%d",&m,&n);
int a[1000][1000];
for(i=0;ifor(j=0;jscanf("%d",&a[i][j]);
}
}
for(i=0;ifor(j=0;jif(a[i][j]>max)
max=a[i][j];
if(a[i][j]printf("%d",ans);
}
两个问题,二维数组a[1000][1000] 定义过大,二是 max min 的初始值可以定义为数组第一个元素a[0][0],修改如下,供参考:
#include<stdio.h>
int main() {
int m, n, i, j, max = 0, min = 0, ans = 0;
scanf("%d%d", &m, &n);
int a[100][100]; //int a[1000][1000]; 修改
for (i = 0; i < m; i++) {
for (j = 0; j < n; j++) {
scanf("%d", &a[i][j]);
}
}
max = min = a[0][0]; //修改
for (i = 0; i < m; i++) {
for (j = 0; j < n; j++) {
if (a[i][j] > max)
max = a[i][j];
if (a[i][j] < min)
min = a[i][j];
}
}
ans = max - min;
printf("%d", ans);
return 0;
}
如果a中数据都是>3的数,那你min=0,a[i][j]<min永远不满足 所以min最后仍然是0,即你的min不正确。应该将min初始化为很大的数