62.指针和二维数组(2)

一.指针和二维数组

1.如a是一个二维数组,则数组中的第i行可以看作是一个一维数组,这个一维数组的数组名是ai

2.ai代表二维数组中第i行的首个元素的地址,即ai0的地址。

二.进一步思考

二维数组可以看作是数组的数组,本质还是一维数组。所以我们可以把二维数组的一行看作是一个数组元素,此时二维数组就会变成一个一维数组。如下图所示

此时,二维数组a22变成了只有俩个元素a0和a1的一维数组。因为在一维数组中p=&a0可以简写成p=a;

所以由此得出:

数组名a就是一维数组元素a0的地址,即二维数组a中第0行的地址。a+1则是二维数组a中第1行的地址。所以a+i则是二维数组a中第i行的地址。

结论:

a+i与ai的地址相同的。

这里需要注意的是:*(a+i)+j才是aij的地址。并不是(a+i)+j是aij的地址。

因为a+i表示的是二维数组中第i行的地址,而不是第i行首个元素的地址,此时a+i表示的是整个第i行数组,*a+i表示的才是第i行数组中首个元素的地址。也就是说虽然a和*a的值相同,但是表示的意义不同。

举例验证:

复制代码
#include <stdio.h>

int main(void)
{
    int a[2][2]={0,1,2,3};
    int i = 0;
    int j = 0;

    for(i=0;i<2;i++){
        for(j=0;j<2;j++){
            printf("a[%d][%d] addr is %p,value is %d\n",i,j,a[i]+j,*(a[i]+j));
        }
    }
    printf("**********************************\n");
    for(i=0;i<2;i++){
        for(j=0;j<2;j++){
            printf("a[%d][%d] addr is %p,value is %d\n",i,j,*(a+i)+j,*(*(a+i)+j));
        }
    }

    printf("%p\n",*a);
    printf("%p\n",*a+1);
    printf("%p\n",a);
    printf("%p\n",a+1);


    return 0;
 
}

运行结果:

三.视频教程

62.指针和二维数组(2)_哔哩哔哩_bilibili

相关推荐
Irissgwe几秒前
二叉树进阶
数据结构·c++·算法·c·二叉搜索树
无限码力2 分钟前
华为非AI方向笔试真题 - 容器镜像平均大小统计
算法·华为·华为非ai方向笔试真题·华为笔试真题·华为非ai笔试真题·华为0612非ai笔试真题
hairenwangmiao2 分钟前
c++排序(第一章----桶排序与sort排序)
数据结构·c++·排序
无限码力5 分钟前
华为非AI方向0612笔试真题-循环异或加密器(详细思路+多语言题解)
算法·华为·华为非ai方向笔试真题·华为笔试真题·华为0612笔试真题
凌波粒7 分钟前
LeetCode--1584. 连接所有点的最小费用(最小生成树/Prim算法/Kruskal算法)
算法·leetcode·职场和发展
xieliyu.7 分钟前
Java数据结构:从0开始手搓Hash桶
java·数据结构·哈希算法
simidagogogo8 分钟前
生产环境推荐系统最隐蔽的坑:Training-Serving Skew 详解与实战
算法·spark·推荐算法
大白话_NOI22 分钟前
【二分答案】附通用模板
c++·算法
三行数学28 分钟前
数学周刊第23期(2026年06月08日-06月14日)南师数科院万仁辉副教授成果登顶国际数学四大顶刊之一<数学年刊>
算法·数学周刊
阿文的代码库31 分钟前
算法专题:独特的电子邮件地址
linux·运维·算法