Menu Close

C语言 – 以数组名作参数的函数

数组名可以作函数的实参和形参。如:

main()
{
   int array[10];
   ……
   ……
   f(array,10);
    ……
    ……
}

f(int arr[],int n);
{
   ……
   ……
}

array 为实参数组名,arr 为形参数组名。在学习指针变量之后就更容易理解这个问题了。数组名就是数组的首地址,实参向形参传送数组名实际上就是传送数组的地址,形参得到该地址后也指向同一数组。

这就好象同一件物品有两个彼此不同的名称一样。形参和实参的数组指向同一个个地址。

例1.计算出五个数的平均值

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;
}

例2.以数组为参数将数组 a 中的 n 个整数按相反顺序存放

void inv(int x[],int n)
{
     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");
}

 

将数组 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 为止,如图所示。

例3. 以指针为参数将数组 a 中的 n 个整数按相反顺序存放

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"); 
}

例4.从 n个数中找出其中最大值和最小值(数组做参数)

int max,min;
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);
 }

 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;
}

说明:

  • 在函数 max_min_value 中求出的最大值和最小值放在 max 和 min 中。由于它们是全局,因此在主函数中可以直接使用;
  • 函数 max_min_value 中的语句:

max=min=*array;
array 是数组名,它接收从实参传来的数组 numuber 的首地址。
*array 相当于*(&array[0])。上述语句与 max=min=array[0];等价。

  • 在执行 for 循环时,p 的初值为 array+1,也就是使 p 指向 array[1]。以后每次执行 p++, 使 p 指向下一个元素。每次将*p 和 max 与 min 比较。将大者放入 max,小者放 min。
  • 函数 max_min_value 的形参 array 可以改为指针变量类型。
  • 实参也可以不用数组名,而用指针变量传递地址。

 

例5.从 n个数中找出其中最大值和最小值(指针做参数)

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[10],*p;
     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);
 }

例6.两维数组作为参数

要将多维数组传递给函数,只需将数组的名称传递给函数(类似于一维数组)。

#include <stdio.h>
void displayNumbers(int num[2][2]);

int main() {
  int num[2][2];
  printf("Enter 4 numbers:\n");
  for (int i = 0; i < 2; ++i) {
    for (int j = 0; j < 2; ++j) {
      scanf("%d", &num[i][j]);
    }
  }

  // pass multi-dimensional array to a function
  displayNumbers(num);

  return 0;
}

void displayNumbers(int num[2][2]) {
  printf("Displaying:\n");
  for (int i = 0; i < 2; ++i) {
    for (int j = 0; j < 2; ++j) {
      printf("%d\n", num[i][j]);
    }
  }
}
结果:
Enter 4 numbers:
2
3
4
5
Displaying:
2
3
4
5

注意函数原型和函数定义中的参数 int num[2][2]:

// function prototype
void displayNumbers(int num[2][2]);

这表示该函数将二维数组作为参数。我们还可以将超过 2 维的数组作为函数参数传递。

传递二维数组时,不一定要指定数组的行数。但是,应始终指定列数。

实参与形参的对应关系有以下4种:

1) 形参和实参都是数组名, a和x指的是同一组数组

main()
{
   int a[10];
   ……
   f(a,10)
   ……
}
  f(int x[],int n)
  {
    ……
  }

2) 实用数组,形参用指针变量

main()
{
   int a[10];
   ……
   f(a,10)
   ……
}
f(int *x,int n)
{
   ……
}

3) 实参、型参都用指针变量

4) 实参为指针变量,型参为数组名

例7.用选择法对10个整数排序

[content_control]

#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");
}
 
void 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;
        }
    }
}

 

[/content_control]

说明:函数 sort 用数组名作为形参,也可改为用指针变量.

 

除教程外,本网站大部分文章来自互联网,如果有内容冒犯到你,请联系我们删除!

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

Leave the field below empty!

Posted in C语言教程

Related Posts