1.数组名表示数组的首地址或第一个元素的地址,等价于&a[0]
2.指针增量与数组的关系:指针增加1,对应增加该数组的一个元素数据类型占的大小
3.指针偏移后,再次使用时,需重新回到数组首地址,不然会超越整个数组内存地址的范围
4.引用数组元素,可通过下标法和指针法
5.指针变量名可用作数组名,即array[1]=p[1]
6.数组名可看作一个指针常量,可直接相加一个常数,但不可连续相加
案例:给数组逆序排序
源程序:
/*逆序输出*/
#include <stdio.h>
void initArr(int *parr,int len)//定义一个指针变量用来存放数组首地址
{
int i;
for(i=0;i<len;i++)
{
printf("请输入第%d元素:",i+1);
scanf("%d",parr++);//parr为指针变量,可直接存放地址
puts("");
}
}
void printArr(int *parr,int len)
{
int i;
printf("你输入的元素是:");
for(i=0;i<len;i++)
{
printf("%d ",*parr++);//*取出指针变量中的值
}
puts("");
}
void revangeArr(int *parr,int len)
{
int i,j;
int temp;
for(i=0;i<len/2;i++)//指针偏移方法
{
j=len-1-i;
temp=*(parr+i);
*(parr+i)=*(parr+j);
*(parr+j)=temp;
}
/*for(i=0;i<len/2;i++)//指针做数组名时的方法
{
j=len-1-i;
temp=parr[i];
parr[i]=parr[j];
parr[j]=temp;
}*/
}
int main()
{
int arr[5];
int len=sizeof(arr)/sizeof(arr[0]);
initArr(&arr[0],len);//实参为数组首地址
printArr(&arr[0],len);
revangeArr(arr,len);
printf("元素逆序:");
int i;
for(i=0;i<len;i++)
{
printf("%d ",arr[i]);
}
puts("");
return 0;
}
程序运行结果: