7.C语言数组名作函数参数

最后更新于:2022-04-01 23:18:09

# 7.C语言数组名作函数参数 数组名可以作函数的实参和形参。如: ~~~ main(){ int array[10]; /* …… */ /* …… */ f(array,10); /* …… */ /* …… */ } f(int arr[],int n); { /* …… */ /* …… */ } ~~~ array为实参数组名,arr为形参数组名。在学习指针变量之后就更容易理解这个问题了。数组名就是数组的首地址,实参向形参传送数组名实际上就是传送数组的地址,形参得到该地址后也指向同一数组。这就好象同一件物品有两个彼此不同的名称一样。 ![](http://www.lvtao.net/content/uploadfile/201404/2eb7b844cf87315a90a8fcd22c5e39cd20140421044205.gif) 同样,指针变量的值也是地址,数组指针变量的值即为数组的首地址,当然也可作为函数的参数使用。 【例10-15】 ~~~ float aver(float *pa); main(){ float sco[5],av,*sp; int i; sp=sco; 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; float av,s=0; for(i=0;i<5;i++) s=s+*pa++; av=s/5; return av; } ~~~ 【例10-16】将数组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为止,如图所示。 ![](http://www.lvtao.net/content/uploadfile/201404/65780ce3b61a0d4d5ea835130d37d7d520140421044206.gif) 程序如下: ~~~ 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,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改成指针变量。 【例10-17】将函数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[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"); } ~~~ 运行情况与前一程序相同。 【例10-18】从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;pmax) max=*p; else if (*pmax) max=*p; else if (*px[k])k=j; if(k!=i){ t=x[i]; x[i]=x[k]; x[k]=t; } } } ~~~ 说明:函数sort用数组名作为形参,也可改为用指针变量,这时函数的首部可以改为:     sort(int *x,int n) 其他可一律不改。
';