指针和数组
- 如果用一个指针指向数组
char *p;
p=a;//语句1
p&a[0];//语句2
只需要用指针指向数组的第一个元素的地址即可,接下来进行指针的运算达到操作数组的目的。
当指针指向数组元素的时候,我们可以对指针变量进行加减运算,这样做的意义相当于指向距离指针所在位置向前或向后的第n个元素。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
char a[]="LOVE";
int b[4]={1,2,3,4};
float c[4]={1.1,2.2,3.3,4.4};
char *p=a;
printf("*p=%c,*(p+1)=%c,*(p+2)=%c\n",*p,*(p+1),*(p+2));
system("pause");
return 0;
}
对比标准的下标法访问数组元素,这种使用指针进行间接访问的方法叫做指针法。
这里的p+1并不是简单的将地址加1,而是指向数组的下一个元素。
指针和数组的区别
- int *p1[5]; 指针数组
指针数组是一个数组,每个数组元素存放一个指针变量。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int a=1;
int b=2;
int c=3;
int d=4;
int e=5;
int *p1[5]={&a,&b,&c,&d,&e};
int i;
for ( i = 0; i < 5; i++)
{
printf("%d\n",*p1[i]);
}
system("pause");
return 0;
}
- int (*p2)[5]; 数组指针
数组指针是一个指针,它指向的是一个数组。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int temp[5]={1,2,3,4,5};
int (*p2)[5]=&temp;
int i;
for ( i = 0; i < 5; i++)
{
printf("%d\n",*(*p2+i));
}
system("pause");
return 0;
}
指针指向的是数组的地址,数组的地址就是数组第一个元素的地址。
指针与二维数组
*(array+i)==array[i]
*((array+i)+j)==array[i][j]
*((*(array+i)+j)+k)==array[i][j][k]
数组指针和二维数组
- 初始化二维数组是可以偷懒的:
int array[2][3]={{0,1,2},{3,4,5}};
可以写成
int array[][3]={{0,1,2},{3,4,5}}; - 定义一个数组指针是这样的:
int (*p)[3]; - 那么请问如何解释下边的语句:
int (*p)[3]=array;
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int array[2][3]={{0,1,2},{3,4,5}};
int (*p)[3]=array;
printf("**(p+1):%d\n",**(p+1));
printf("**(array+1):%d\n",**(array+1));
printf("array[1][0]:%d\n",array[1][0]);
printf("*(*(p+1)+2):%d\n",*(*(p+1)+2));
printf("*(*(array+1)+2):%d\n",*(*(array+1)+2));
printf("array[1][2]:%d\n",array[1][2]);
system("pause");
return 0;
}
由此可见将数组指针指向二维数组即可用指针表示数组里面的值。