int r,c;
int max_i = 0,max_j = 0,min_i=0,min_j=0;
int a[r][c];
int max=0,min=0;
printf("请输入二维数组行(r),列(c):\n");
scanf("%d%d",&r,&c);
printf("请输入数据:");
for (int i=0; i<r; i++) { //输入数据
for (int j=0; j<c ; j++) {
scanf("%d",&a[i][j]);
printf("%d \t",a[i][j]);
if (min>a[i][j]) {
min=a[i][j];
min_i=i;
min_j=j;}
if (max<a[i][j]) {
max=a[i][j];
max_i=i;
max_j=j;
}
// min=a[0][0];
}
}
printf("最大数为:%d。下标为(%d , %d)\n",max,max_i,max_j);
printf("最小数为:%d。下标为(%d , %d)\n",min,min_i,min_j);
return 0;
为什么只能输出最大值和下标,不能输出最小值和下标,求大神告知
很明显,你这个程序有问题
问题是:你把最大最小值初始化为0了,然后拿0和你输入的值进行比较。
你说只能输入最大值,可能你输入的全部是正数。
举个例子
2*2的矩阵
我输入 1 2 3 4,你的程序最大值为0,但是最小值就是0
我输入-1 -2 -3 -4 , 你程序最大值为0,最小值为-4
这明显是不合理的
建议在 printf("%d \t",a[i][j]); 后加上即可
if((i == 0)&&(j == 0))
{
min = max = a[0][0];
}
可以通过两个指针实现在O(n)时间复杂度内完成比较
肯定可以啊 ,如果在源程序上修改的话,添加一段代码和求最大值相反就可以
if (min>a[i][j]) {
min=a[i][j];
min_i=i;
min_j=j;
}
最好把最小和最大设为前两个数比较后的最小和最大
额,所的有问题,再重说一遍。
很明显,你这个程序有问题
问题是:你把最大最小值初始化为0了,然后拿0和你输入的值进行比较。
你说只能输出最大值,可能你输入的全部是正数。
举个例子
2*2的矩阵
我输入 1 2 3 4,你的程序最大值为4,但是最小值就是0
我输入-1 -2 -3 -4 , 你程序最大值为0,最小值为-4
这明显是不合理的
建议在 printf("%d \t",a[i][j]); 后加上即可
if((i == 0)&&(j == 0))
{
min = max = a[0][0];
}