博客
关于我
c语言之指向二维数组元素的指针变量
阅读量:462 次
发布时间:2019-03-06

本文共 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/

    你可能感兴趣的文章
    Numpy:条件总和
    查看>>
    numpy、cv2等操作图片基本操作
    查看>>
    numpy中的argsort的用法
    查看>>
    NumPy中的精度:比较数字时的问题
    查看>>
    numpy判断对应位置是否相等,all、any的使用
    查看>>
    Numpy多项式.Polynomial.fit()给出的系数与多项式.Polyfit()不同
    查看>>
    Numpy如何使用np.umprod重写range函数中i的python
    查看>>
    numpy学习笔记3-array切片
    查看>>
    numpy数组替换其中的值(如1替换为255)
    查看>>
    numpy数组索引-ChatGPT4o作答
    查看>>
    NUMPY矢量化np.prod不能构造具有超过32个操作数的ufunc
    查看>>
    Numpy矩阵与通用函数
    查看>>
    numpy绘制热力图
    查看>>
    numpy转PIL 报错TypeError: Cannot handle this data type
    查看>>
    Numpy闯关100题,我闯了95关,你呢?
    查看>>
    nump模块
    查看>>
    Nutch + solr 这个配合不错哦
    查看>>
    NuttX 构建系统
    查看>>
    NutUI:京东风格的轻量级 Vue 组件库
    查看>>
    NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
    查看>>