本实例要求使用二维数组将一个 3×4 的矩阵中所有元素的最大值及其下标获取,通过该程序,掌握二维数组的引用知识。

算法思想:

针对本实例,有两个步骤需要编写程序完成:第一个步骤是求矩阵元素的最大值,可以通过相邻的元素大小比较,最终获取最大值;第二个步骤是针对获取到的元素最大值,求该元素的下标。

二维数组元素的一般表示方法为:“数组名[下标][下标]”。对于二维数组,下标变量和数组说明在表示形式上是一样的,比如在本例中,有语句:int a[3][4]; a[3][4]=2/3;

上述语句中“a[3][4]”是完全不同的两个概念,第一个语句中的“a[3][4]”用来定义一个数组,而第二个语句中的“a[3][4]”是一个双下标变量。

#include <stdio.h>

int main(void) {
    int a[3][4], i, j, max, max_i = 0, max_j = 0;
    for (i = 0; i < 3; ++i) {
        for (j = 0; j < 4; ++j) {
            scanf("%d",&a[i][j]);
        }
    }
    max=a[0][0];
    for (i = 0; i < 3; ++i) {
        for (j = 0; j < 4; ++j) {
            if(a[i][j]>max){
                max=a[i][j];
                max_i=i;
                max_j=j;
            }
        }
    }
    printf("max=a[%d][%d]=%d\n",max_i,max_j,max);

    return 0;
}

输出结果:

1 2 3 4 5 6 7 99 9 10 11 12
max=a[1][3]=99

技术要点:

本实训的程序主要完成了两个功能:一是通过一个二次循环输入该二维数组的所有元素;二是将输入元素按照相邻关系进行比较,最终得到最大值和这个最大值的下标。