2 qq 17583689 qq_17583689 于 2016.03.10 10:03 提问

关于二维数组的输出最大值最小值以及下标的问题
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;

为什么只能输出最大值和下标,不能输出最小值和下标,求大神告知

5个回答

fickyou
fickyou   2016.03.10 11:04
已采纳

很明显,你这个程序有问题

问题是:你把最大最小值初始化为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];
}

fickyou
fickyou   2016.03.10 11:06

额,所的有问题,再重说一遍。

很明显,你这个程序有问题

问题是:你把最大最小值初始化为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];
}

hou_weiyi
hou_weiyi   2016.03.10 10:35
  if (min>a[i][j]) {
        min=a[i][j];
        min_i=i;
        min_j=j;
}

最好把最小和最大设为前两个数比较后的最小和最大

qq_21792169
qq_21792169   2016.03.10 10:22

肯定可以啊 ,如果在源程序上修改的话,添加一段代码和求最大值相反就可以

John_ToStr
John_ToStr   Rxr 2016.03.10 15:04

可以通过两个指针实现在O(n)时间复杂度内完成比较

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
4.编程打印一个二维数组中所有元素的和,并打印最大值,最小值(以及它们所在的行号和列号)
/*晕呀,竟然做了一天,还不知道怎样做出来的。。。。。*/ package HomeWork; import java.util.Arrays; /*4.编程打印一个二维数组中所有元素的和,并打印最大值,最小值(以及它们所在的行号和列号) void printResult(int a[][]){......} 输出结果格式: 二维数组中所有元素的和是:123 最大值是:15,行号:3
二维数组的最大值和最小值
#include int main(int argc, const char * argv[]) {          int arr[3][4]={34,13,45,67,42,78,56,10,58,45,78,98};     int arr1[3][4];          for (int i=0; i3; i++)//输出所
求二维数组中的最大值 最小值及其下标
/* *程序的版权和版本声明部分: *Copyright(c)2013,烟台大学计算机学院学生 *All rights reserved. *文件名称: *作者:尚振伟 *完成日期:2013年 12月19日 *版本号:v0.1
Java 299之输出二维数组中的最大值
import java.util.Scanner; public class Twodimensional { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub System.out.printf("Enter t
java如何求二维数组的和、最大值和最小值。
package com.aray.sectest; public class SecondArray { public static void main(String[] args) { //int a[][]= new int[][]{{121,3,121},{121,1212,1212},{121,1212,1212}};//静态分配数组空间 int a[][]=new i
求3行5列二维数组中每列最小值,及最小值在数组中的行号和列号,并输出。
#include int main(void) { int a[3][5],min,i,j,m=1; for(i=0;i<3;i++) { for(j=0;j<5;j++) scanf("%d",&a[i][j]); } for(j=0;j<5;j++) { min=a[0][j]; for(i=0;i<3;i++) if(a[i][j]<min) {
二维数组求最小值,函数调用
// 121211 作业4.cpp : 定义控制台应用程序的入口点。 // /* * Copyright (c) 2012, 烟台大学计算机学院 * All rights reserved. * 作 者: 刘同宾 * 完成日期:2012 年 12 月 11 日 * 版 本 号:v1.0 *
求二维数组中最大最小值及行列号
c语言上机考试专用,简单易操作,求二维数组的最大最小值及行列号
利用二维数组存储一个3行4列的单位矩阵,并输出最大值和最小值
#include void main() {  int i,j,a[3][4];  int max,min;  for(i=0;i  {   for(j=0;j    cin>>a[i][j];  }  for(i=0;i  {     cout   for(j=0;j   cout  }     max=a[0][0];     min=a[0][0];
求二维数组最大最小值----利用函数调用形式(2种方法)
(1)利用冒泡排序思想求二维数组中的最大值 /* 利用函数调用形式,传递二维数组名进行函数调用 设计求二维数组中最小值、最大值的函数,在主函数中调用 利用冒泡排序思想求二维数组最大值。 算法思想:先对各行进行一次冒泡排序,使每行的最后一个数为当前行中最大值, 即二维数组中的最后一列中的数,都是本行中的最大值。 然后对二维数组中的最后一列进行一次冒泡排序,得到最后一列的最后