- main()
- {int array[10];
- ……
- ……
- f(array,10);
- ……
- ……
- }
- f(int arr[],int n);
- {
- ……
- ……
- }
array为实参数组名,arr为形参数组名。在学习指针变量之后就更容易理解这个问题了。数组名就是数组的首地址,实参向形参传送数组名实际上就是传送数组的地址,形参得到该地址后也指向同一数组。这就好象同一件物品有两个彼此不同的名称一样。
同样,指针变量的值也是地址,数组指针变量的值即为数组的首地址,当然也可作为函数的参数使用。
【例6.1】
- #include <stdio.h>
- float aver(float *pa);
- main()
- {
- float sco[5]={0},av=0,*sp=sco;
- int i=0;
- printf("\ninput 5 scores:\n");
- for(i=0;i<5;i++)
- scanf("%f",&sco[i]);
- av=aver(sp);
- printf("average score is %5.2f",av);
- }
- float aver(float *pa)
- {
- int i=0;
- float av=0,s=0;
- for(i=0;i<5;i++)
- ss=s+*pa++;
- av=s/5;
- return av;
- }
【例6.2】将数组a中的n个整数按相反顺序存放。
算法为:将a[0]与a[n-1]对换,再a[1]与a[n-2] 对换……,直到将a[(n-1/2)]与a[n-int((n-1)/2)]对换。今用循环处理此问题,设两个“位置指示变量”i和j,i的初值为0,j 的初值为n-1。将a[i]与a[j]交换,然后使i的值加1,j的值减1,再将a[i]与a[j]交换,直到i=(n-1)/2为止,如图所示。
程序如下:
- #include <stdio.h>
- 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[i];x[i]=x[j];x[j]=temp;
- }
- return;
- }
- main()
- {
- int i=0,a[10]={3,7,9,11,0,6,7,5,4,2};
- printf("The original array:\n");
- for(i=0;i<10;i++)
- printf("%d,",a[i]);
- printf("\n");
- inv(a,10);
- printf("The array has benn inverted:\n");
- for(i=0;i<10;i++)
- printf("%d,",a[i]);
- printf("\n");
- }
对此程序可以作一些改动。将函数inv中的形参x改成指针变量。
【例6.3】对例10.16可以作一些改动。将函数inv中的形参x改成指针变量。
程序如下:
- #include <stdio.h>
- 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[10]={3,7,9,11,0,6,7,5,4,2};
- printf("The original array:\n");
- for(i=0;i<10;i++)
- printf("%d,",a[i]);
- printf("\n");
- inv(a,10);
- printf("The array has benn inverted:\n");
- for(i=0;i<10;i++)
- printf("%d,",a[i]);
- printf("\n");
- }
运行情况与前一程序相同。
【6.4】从10个数中找出其中最大值和最小值。
调用一个函数只能得到一个返回值,今用全局变量在函数之间“传递”数据。程序如下:
- #include <stdio.h>
- int max,min; /*全局变量*/
- void max_min_value(int array[],int n)
- {
- int *p,*array_end;
- arrayarray_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[10];
- printf("enter 10 integer umbers:\n");
- for(i=0;i<10;i++)
- scanf("%d",&number[i]);
- max_min_value(number,10);
- printf("\nmax=%d,min=%d\n",max,min);
- }
说明:
2.实参用数组,形参用指针变量。
}
【例10.20】用实参指针变量改写将n个整数按相反顺序存放。
- #include <stdio.h>
- 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[10]={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");
- }
注意:main函数中的指针变量p是有确定值的。即如果用指针变作实参,必须现使指针变量有确定值,指向一个已定义的数组。
【例10.21】用选择法对10个整数排序。
- #include <stdio.h>
- main()
- {
- int *p,i,a[10]={3,7,9,11,0,6,7,5,4,2};
- printf("The original array:\n");
- for(i=0;i<10;i++)
- printf("%d,",a[i]);
- printf("\n");
- p=a;
- sort(p,10);
- for(p=a,i=0;i<10;i++)
- {printf("%d ",*p);p++;}
- printf("\n");
- }
- sort(int x[],int n)
- {
- int i,j,k,t;
- for(i=0;i<n-1;i++)
- {k=i;
- for(j=i+1;j<n;j++)
- if(x[j]>x[k])k=j;
- if(k!=i)
- {t=x[i];x[i]=x[k];x[k]=t;}
- }
- }