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

一.指针和二维数组

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

2.a[i]代表二维数组中第i行的首个元素的地址,即a[i][0]的地址。

二.进一步思考

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

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

所以由此得出:

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

结论:

a+i与a[i]的地址相同的。

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

因为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

相关推荐
放下华子我只抽RuiKe52 小时前
算法的试金石:模型训练、评估与调优的艺术
人工智能·深度学习·算法·机器学习·自然语言处理·数据挖掘·线性回归
oem1102 小时前
C++中的享元模式实战
开发语言·c++·算法
流云鹤2 小时前
每日一题0316
算法
leonkay3 小时前
Golang语言闭包完全指南
开发语言·数据结构·后端·算法·架构·golang
颜酱4 小时前
BFS 与并查集实战总结:从基础框架到刷题落地
javascript·后端·算法
casual~4 小时前
第?个质数(埃氏筛算法)
数据结构·c++·算法
仰泳的熊猫5 小时前
题目2308:蓝桥杯2019年第十届省赛真题-旋转
数据结构·c++·算法·蓝桥杯
hssfscv5 小时前
力扣练习训练2(java)——二叉树的中序遍历、对称二叉树、二叉树的最大深度、买卖股票的最佳时机
java·数据结构·算法
y = xⁿ6 小时前
【LeetCodehot100】二叉树大合集 T94:二叉树的中序遍历 T104:二叉树的最大深度 T226:翻转二叉树 T101:对称二叉树
后端·算法·深度优先
不想看见4046 小时前
Search a 2D Matrix II数组--力扣101算法题解笔记
数据结构·算法