本文共 1110 字,大约阅读时间需要 3 分钟。
如何使用指针对二维数组进行遍历?
在编程过程中,经常需要对二维数组进行遍历操作。使用指针来实现这一点既是高效的方法,也是许多开发者熟悉的技巧。以下将详细介绍如何利用指针对二维数组进行遍历。
首先,我们需要明确二维数组在内存中的结构。例如,对于一个二维数组int a[2][3] = { {1,2,3}, {4,5,6} },可以看作是两个一维数组构成的。具体来说,int a[0][3] = {1,2,3} 和 int a[1][3] = {4,5,6}。我们知道,一维数组在内存中是连续的,且数组名a[0]和a[1]分别代表它们的首元素地址。由于二维数组的内存地址也是连续的,a[1]的首元素地址即为a[0]首元素地址加上a[0]中元素的个数。因此,我们可以通过让指针不断+1来访问其中的每一个元素,无需再次考虑行与列的限制。
以下是一个使用指针遍历二维数组的示例代码:
#include#include void printArr(int *p, int m, int n) { for (int i = 0; i < (m * n); i++) { if (i != 0 && i % n == 0) { printf("\n"); } printf("%d ", *(p + i)); } putchar('\n');}int main() { int a[2][3] = { {1,2,3}, {4,5,6} }; int m = sizeof(a) / sizeof(a[0]); int n = sizeof(a[0]) / sizeof(a[0][0]); printf("数组的行:%d 数组的列:%d\n", m, n); printArr(a, m, n); system("pause"); return 0;}
输出结果:
数组的行:2 数组的列:31 2 34 5 6
需要注意以下几点:
int m = sizeof(a) / sizeof(a[0]); 和 int n = sizeof(a[0]) / sizeof(a[0][0]); 来获取数组的行与列。printArr 函数中的是二维数组首元素的地址,即第一个一维数组的首元素地址,即其名字。p 一直向后移动到二维数组的末尾,可以看作将二维数组展开成一维数组,再计算移动的次数。转载地址:http://ifsbz.baihongyu.com/