C语言详解:数组指针

数组指针是指针

int* p[10] 这是指针数组的写法 ,因为【】的优先级比*高,

所以为了解决优先级问题,加()

cpp 复制代码
int(* p)[10]=&arr;//数组的地址要存起来

说明p是指针(首先与*结合),指向的类型是int[10],指向的是数组

cpp 复制代码
int  main()
{
	int* p = NULL;//p是整形指针-指向整形的指针-可以存放整形的地址
	char* pc = NULL;//pc是字符指针-指向字符的指针-可以存放字符的地址
	              //数组指针-指向数组的指针-可以存放数组的地址
	int arr[10] = { 0 };
	//arr -首元素地址
	//&arr[0]-首元素地址
	//&arr-数组的地址  刚好可以用数组指针存放
	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int(* p)[10]=&arr;//数组的地址要存起来
	return 0;
}

下面的代码如何理解呢?

cpp 复制代码
int main()
{
	char* arr[5];
	char(*pa)[5] = &arr;//错了
	char* (*pa)[5] = &arr;//正确
}

解释一下,arr是指针数组,五个元素是指针,&arr之后,拿到的是数组的地址,所以要用指针数组,但是数组的类型是什么呢?是char*,为啥呢,比如int arr【5】,arr 5个元素是int 型,而我arr的元素是char*的类型。

指针数组改怎么用呢?

在一维数组的用法,代码如下,可以看到用起来很复杂啊,解释一下,*pa=arr;就是首元素地址,首元素地址加i就拿到各个地址,然后解引用,也可以按数组的表示来

cpp 复制代码
int main()
{
	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int(*pa)[10] = &arr;
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		/*printf("%d ", (*pa)[i]);*/
		//printf("\n");
		printf("%d ", *(*pa + i));
	}
	return 0;
}

对比一下:直接用指针写的话,可以看出代码简单很多,所以二维数组的使用一般用于二维数组以上才OK

cpp 复制代码
int main()
{
	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int* p = arr;
	int i = 0;
	for(i=0;i<10;i++)
	{
		printf("%d ", *(p + i));
	}
	return 0;
}

我们之前学过为二维数组的打印,下面代码就是最基本的方法,下面我们要用二维数组进行打印

cpp 复制代码
void print1(int arr[3][5], int x, int y)
{
	int i = 0;
	int j = 0;
	for (i = 0; i < x; i++)
	{
		for (j = 0; j < y; j++)
		{
			printf("%d ", arr[i][j]);
		}
		printf("\n");
	}
}
int main()
{
	int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7} };
	print1(arr, 3, 5);
	return 0;
}

arr是数组名,即首元素地址,我们知道,二维数组可以看成一维数组,所以二维数组的首元素地址不是第一行第一列的元素的地址,而是第一行元素的地址。也就是一个一维数组的地址,,对于一个数组的地址,我们可以用指针数组来指向。

cpp 复制代码
void print2(int(*p)[5], int x, int y)
{
	int i = 0;
	for (i = 0; i < x; i++)
	{
		int j = 0;
		for (j = 0; j < y; j++)
		{
			printf("%d ", *(*(p + i) + j));
		}
		printf("\n");
	}
}
int main()
{
	int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7} };
	print2(arr, 3, 5);
	return 0;
}

*(p+i)就可以拿到每一行的地址,每一行的地址再加j,就可以得到每一个元素的地址。再解引用。当然也可以用数组的表示方法来

cpp 复制代码
printf("%d ", (*(p + i))[j]);

可以参考一下一维数组的方式来理解。其实表示方式还是有很多种的,

cpp 复制代码
arr[i]==*(arr+i)==*(p+i)==p[i]

自己可以在琢磨一下,

cpp 复制代码
printf("%d ", p[i][j]);
printf("%d ", *(p[i]+j);

最后,解释一下 int(*parr3[10])[5] 代表什么意思。

parr3首先与【】结合,说明是数组,数组的类型是int(*)【5】,就是我们本节学的指针数组,

说明该数组有10个元素,每个元素是一个数组指针,该数组指针指向的数组右5个元素,每个元素的类型是int 型。

画图解释一下:

相关推荐
爱吃生蚝的于勒1 小时前
C语言内存函数
c语言·开发语言·数据结构·c++·学习·算法
失落的香蕉4 小时前
C语言串讲-2之指针和结构体
java·c语言·开发语言
ChoSeitaku6 小时前
链表循环及差集相关算法题|判断循环双链表是否对称|两循环单链表合并成循环链表|使双向循环链表有序|单循环链表改双向循环链表|两链表的差集(C)
c语言·算法·链表
DdddJMs__1356 小时前
C语言 | Leetcode C语言题解之第557题反转字符串中的单词III
c语言·leetcode·题解
Fuxiao___6 小时前
不使用递归的决策树生成算法
算法
我爱工作&工作love我6 小时前
1435:【例题3】曲线 一本通 代替三分
c++·算法
娃娃丢没有坏心思7 小时前
C++20 概念与约束(2)—— 初识概念与约束
c语言·c++·现代c++
白-胖-子7 小时前
【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字
开发语言·c++·算法·蓝桥杯·等考·13级
workflower7 小时前
数据结构练习题和答案
数据结构·算法·链表·线性回归
好睡凯7 小时前
c++写一个死锁并且自己解锁
开发语言·c++·算法