21春吉大《c语言程序设计》复习资料(七)
吉大《C语言程序设计》拓展资源(七)C语言指针编程说明
【例 1】输出数组中的全部元素。(用指针变量指向元素)
main(){
int a,I,*p;
p=a;
for(i=0;i<10;i++)
??? *(p+i)=i;
for(i=0;i<10;i++)
??? printf("a[%d]=%d\n",i,*(p+i));
}【例 2】
main(){
int a,i,*p=a;
for(i=0;i<10;){
??? *p=i;
??? printf("a[%d]=%d\n",i++,*p++);
}
}几个注意的问题:
1) 指针变量可以实现本身的值的改变。如p++是合法的;而a++是错误的。因为a是数组名,它是数组的首地址,是常量。
2) 要注意指针变量的当前值。请看下面的程序。
【例 3】找出错误。
main(){
int *p,i,a;
p=a;
for(i=0;i<10;i++)
??? *p++=i;
for(i=0;i<10;i++)
??? printf("a[%d]=%d\n",i,*p++);
}【例 4】改正。
main(){
int *p,i,a;
p=a;
for(i=0;i<10;i++)
*p++=i;
p=a;
for(i=0;i<10;i++)
??? printf("a[%d]=%d\n",i,*p++);
}3) 从上例可以看出,虽然定义数组时指定它包含10个元素,但指针变量可以指到数组以后的内存单元,系统并不认为非法。
4) *p++,由于++和*同优先级,结合方向自右而左,等价于*(p++)。
5) *(p++)与*(++p)作用不同。若p的初值为a,则*(p++)等价a,*(++p)等价a。
6) (*p)++表示p所指向的元素值加1。
7) 如果p当前指向a数组中的第i个元素,则
*(p--)相当于a;
*(++p)相当于a[++i];
*(--p)相当于a[--i]。
3.3 数组名作函数参数
数组名可以作函数的实参和形参。如:main()
{int array;
?? ……
?? ……
f(array,10);
……
??? ……
}
f(int arr[],int n);
???? {
……
??? ……
}
array为实参数组名,arr为形参数组名。在学习指针变量之后就更容易理解这个问题了。数组名就是数组的首地址,实参向形参传送数组名实际上就是传送数组的地址,形参得到该地址后也指向同一数组。这就好象同一件物品有两个彼此不同的名称一样。??? 同样,指针变量的值也是地址,数组指针变量的值即为数组的首地址,当然也可作为函数的参数使用。
【例 5】
float aver(float *pa);
main(){
float sco,av,*sp;
int i;
sp=sco;
printf("\ninput 5 scores:\n");
for(i=0;i<5;i++) scanf("%f",&sco);
av=aver(sp);
printf("average score is %5.2f",av);
}
float aver(float *pa)
{
int i;
float av,s=0;
for(i=0;i<5;i++) s=s+*pa++;
av=s/5;
return av;
}【例 6】将数组a中的n个整数按相反顺序存放。
算法为:将a与a对换,再a与a 对换……,直到将a[(n-1/2)]与a对换。今用循环处理此问题,设两个“位置指示变量”i和j,i的初值为0,j的初值为n-1。将a与a交换,然后使i的值加1,j的值减1,再将a与a交换,直到i=(n-1)/2为止,如图所示。程序如下:
void inv(int x[],int n)?? /*形参x是数组名*/
{
int temp,i,j,m=(n-1)/2;
for(i=0;i<=m;i++)
{j=n-1-i;
?? temp=x;x=x;x=temp;}
return;
}
main()
{int i,a={3,7,9,11,0,6,7,5,4,2};
printf("The original array:\n");
for(i=0;i<10;i++)
?? printf("%d,",a);
printf("\n");
inv(a,10);
printf("The array has benn inverted:\n");
for(i=0;i<10;i++)
printf("%d,",a);
printf("\n");
}对此程序可以作一些改动。将函数inv中的形参x改成指针变量。
【例 7】对例 16可以作一些改动。将函数inv中的形参x改成指针变量。
程序如下:
void inv(int *x,int n)?? /*形参x为指针变量*/
{
int *p,temp,*i,*j,m=(n-1)/2;
i=x;j=x+n-1;p=x+m;
for(;i<=p;i++,j--)
{temp=*i;*i=*j;*j=temp;}
return;
}
main()
{int i,a={3,7,9,11,0,6,7,5,4,2};
printf("The original array:\n");
for(i=0;i<10;i++)
?? printf("%d,",a);
printf("\n");
inv(a,10);
printf("The array has benn inverted:\n");
for(i=0;i<10;i++)
printf("%d,",a);
printf("\n");
}运行情况与前一程序相同。
【例 8】从0个数中找出其中最大值和最小值。
调用一个函数只能得到一个返回值,今用全局变量在函数之间“传递”数据。程序如下:
int max,min;????? /*全局变量*/
void max_min_value(int array[],int n)
{int *p,*array_end;
array_end=array+n;
max=min=*array;
for(p=array+1;p<array_end;p++)
?? if(*p>max)max=*p;
?? else if (*p<min)min=*p;
return;
}
main()
{int i,number;
printf("enter 10 integer umbers:\n");
for(i=0;i<10;i++)
?? scanf("%d",&number);
max_min_value(number,10);
printf("\nmax=%d,min=%d\n",max,min);
}说明:
1) 在函数max_min_value中求出的最大值和最小值放在max和min中。由于它们是全局,因此在主函数中可以直接使用。
2) 函数max_min_value中的语句:
max=min=*array;
array是数组名,它接收从实参传来的数组numuber的首地址。
*array相当于*(&array)。上述语句与 max=min=array;等价。
3) 在执行for循环时,p的初值为array+1,也就是使p指向array。以后每次执行p++,使p指向下一个元素。每次将*p和max与min比较。将大者放入max,小者放min。4) 函数max_min_value的形参array可以改为指针变量类型。实参也可以不用数组名,而用指针变量传递地址。
【例 9】程序可改为:
int max,min;????? /*全局变量*/
void max_min_value(int *array,int n)
{int *p,*array_end;
array_end=array+n;
max=min=*array;
for(p=array+1;p<array_end;p++)
?? if(*p>max)max=*p;
?? else if (*p<min)min=*p;
return;
}
main()
{int i,number,*p;
p=number;???????????? /*使p指向number数组*/
printf("enter 10 integer umbers:\n");
for(i=0;i<10;i++,p++)
?? scanf("%d",p);
p=number;
max_min_value(p,10);
printf("\nmax=%d,min=%d\n",max,min);
}归纳起来,如果有一个实参数组,想在函数中改变此数组的元素的值,实参与形参的对应关系有以下4种:
1) 形参和实参都是数组名。main()
{int a;
……
f(a,10)
……
f(int x[],int n)
{
……
}}
a和x指的是同一组数组。
2) 实用数组,形参用指针变量。main()
{int a;
……
f(a,10)
……
f(int *x,int n)
{
……
}}
3) 实参、型参都用指针变量。
4) 实参为指针变量,型参为数组名。
【例 10】用实参指针变量改写将n个整数按相反顺序存放。
void inv(int *x,int n)
{int *p,m,temp,*i,*j;
m=(n-1)/2;
i=x;j=x+n-1;p=x+m;
for(;i<=p;i++,j--)
?? {temp=*i;*i=*j;*j=temp;}
return;
}
main()
{int i,arr={3,7,9,11,0,6,7,5,4,2},*p;
p=arr;
printf("The original array:\n");
for(i=0;i<10;i++,p++)
?? printf("%d,",*p);
printf("\n");
p=arr;
inv(p,10);
printf("The array has benn inverted:\n");
for(p=arr;p<arr+10;p++)
printf("%d,",*p);
printf("\n");
}转载注明无忧答案网
页:
[1]