通过数组指针来遍历二维数组

  • Post author:
  • Post category:其他


最基本的遍历二维数组的方式如下:

//参数是数组的形式
void print1(int arr[3][5], int x, int y) {
    int i = 0;
    for (i = 0; i < x; i++) {
        int j = 0;
        for (j = 0; j < y; j++) {
            printf("%d ", arr[i][j]);
        }
        printf("\n");
    }
}
int main() {
    int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7,} };
    print1(arr, 3, 5);
    return 0;
}

利用数组指针遍历代码如下:

//参数是数组指针的形式
void print2(int(*pa)[5], int x, int y) {
    int i = 0;
    for (i = 0; i < x; i++) {
        int j = 0;
        for (j = 0; j < y; j++) {
            printf("%d ", *((*pa + i) + j));  
        }
        printf("\n");
    }
}

int main() {
    int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7,} };
    print2(arr, 3, 5);
    return 0;
}

arr[3][5]可以简单的看作如下的存放形式:

1

2

3

4

5

2

3

4

5

6

3

4

5

6

7

而arr是数组首元素地址,而二维数组的首元素地址其实是第一行的一维数组的地址。

即: int (*pa)[5]=arr;

注:二维数组的首地址是第一行地址。



版权声明:本文为m0_63006478原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。