指针:C语言二级指针与二维数组

前言

  最近用C语言写LeetCode 有的题目给的函数把二维数组用二级指针传进来 并传入行数和列数 引起一些疑惑

本来以为C语言学得海星,查了一些资料后,觉得自己还是个弟弟 : (


按一维数组的思路处理二维数组,将二维数组名作为二级指针传入
在这里插入图片描述

出现异常(图示运行在DEVC++中)

在这里插入图片描述

二维数组名+1相当于在行上+1
然而传入的二级指针

在这里插入图片描述

按二维指针指针传入的num失去了二维数组的性质,相当于仅进行了数组首地址的传递,和一个普通的int *指针没有区别

在这里插入图片描述
仅进行了地址值的传递,甚至可凭借数组的连续性按一维数组的方式来访问元素



那怎么传递二维数组呢?

如果行列数已知,可以用如下方法
在这里插入图片描述
这里列下标是必填的,因为只有确定了列下标,程序才知道计算num[i]这种地址时该以多少个元素作为一行,由num+1的结果也可以看出num已经是正常的二维数组名了

也可以用int (*num)[3],效果与int num[ ][3]等价
int (*num)[3] 说明num是一个指向有三个int元素数组的指针,所以步长也为3 × sizeof(int),同用一维数组访问的方式类似



那如何以指针形式进行访问呢?
除了上面以一维数组的方式进行访问外,还可以将二维数组还原回来

void test(int **num, int row, int col) {
	int **p = (int **)malloc(sizeof(int *)*row);
	或者int *p[2];//int *p[row];
	for(int i = 0;i<row;i++){
		p[i] = num+i*col;
	}
	printf("num[1][1] = %d\n", p[1][1]);//输出为4
	free(p);
}

int main() {
	int num[2][3]= {{0,1,2},{3,4,5}};
	test(num,2,3);
	return 0;
}


2019/04/09

会再更新指针的博客的

发布了85 篇原创文章 · 获赞 83 · 访问量 4万+

猜你喜欢

转载自blog.csdn.net/kafmws/article/details/89134731
今日推荐