数组指针:是指针;指向数组的指针;用来存放数组的地址
int arr[10] = { 0 };
arr --首元素地址
&arr[0] --首元素的地址
&arr --数组的地址
int main()
{
int *p = NULL; //P是整形指针 - 指向整形的指针--可以存放整形的地址
char *p = NULL; //pc是字符指针 - 指向字符的指针 - 可以存放字符的地址
// 数组指针 - 指向数组的指针 - 存放数组的地址
int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int(*p)[10] = &arr; //数组的地址要存放起来
//上面的p就是指针数组
}
利用数组指针打印二维数组
#include <stdio.h>
//参数为数组的形式
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");
}
}
参数是指针的形式
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("%d ", *(*(p + i) + 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 } };
print1(arr, 3, 5); //arr - 数组名--数组名就是首元素地址
print2(arr, 3, 5);
return 0;
}
结果: