指向数组元素的指针变量
例:
int array[10];
int *p;
p=&array[0];
//int *p=&array[0];
//int *p=array; //数组名是表示数组首地址的地址常量,数组名array是地址常量不能被赋值,而p是指针变量可以被赋值;
指针变量的赋值运算:
p=&a; //把a变量地址->p
p=array; //将数组array的首地址->p
p=%array[i]; //将数组元素的首地址->p
p1=p2; //p1与p2指向同一个存储空间
指针变量与其指向的变量具有相同的数据类型
以下是错误的写法:
int i,*p;
p=1000;
i=p;
应用:
int a[3]={1,2,3};
int *p;
p=&a[0];
p++;
*p=87;
printf("%d",a[1]); //输出的a[1]是87
若p1、p2指向同一数组
p1<p2; p1指向的元素在前
p1>p2; p1指向的元素在后
p1==p2; p1、p2指向同一个元素
int a[]={1,2,3,4,5,6,7,8,9,0},*p=a,i;
//则数组元素的正确表示为&p[i];
数组与指针的关系如图:
a[i]=p[i]<=>* (p+i)=*(a+i)
数组元素的表示方法:
下标法和指针法。
即若:p=a;则:p[i]<=>a[i]<=>* (p+i)<=>* (a+i)
用不同的方法对数据进行输入和输出:
#include<stdio.h>
int main(void){
//普通方法
/*
int a[5],i;
for(i=0;i<5;i++){
scanf("%d",&a[i]);
}
for(i=0;i<5;i++){
printf("%d",a[i]);
}
*/
//数组名的方法,不常用
/*
int a[5],i;
for(i=0;i<5;i++){
scanf("%d",a+i);
}
for(i=0;i<5;i++){
printf("%d",*(a+i));
}
*/
//指针变量下标法 (较常用)
/*
int a[5],i;
int *p;
p=a;
for(i=0;i<5;i++){
scanf("%d",&p[i]);
}
p=a;
for(i=0;i<5;i++){
printf("%d",p[i]);
}
*/
//指针变量指针法 (高效)
int a[5],i;
int *p;
p=a;
for(i=0;i<5;i++){
scanf("%d",p++);
}
p=a; //不可去掉
for(i=0;i<5;i++){
printf("%d",*(p++));
}
return 0;
}