C语言数组作为函数参数

数组可以作为函数的参数使用,进行数据传送。数组用作函数参数有两种形式,一种是把数组元素(下标变量)作为实参使用;另一种是把数组名作为函数的形参和实参使用。

数组元素作函数实参

数组元素就是下标变量,它与普通变量并无区别。 因此它作为函数实参使用与普通变量是完全相同的,在发生函数调用时,把作为实参的数组元素的值传送给形参,实现单向的值传送。【例5-4】说明了这种情况。【例8-7】判别一个整数数组中各元素的值,若大于0 则输出该值,若小于等于0则输出0值。编程如下:

#include

voidnzp(intv){

if(v>0)

printf("%d ",v);

else

printf("%d ",0);

}

intmain(void){

inta[5],i;

printf("input 5 numbers\n");

for(i=0;i<5;i++){

scanf("%d",&a[i]);

nzp(a[i]);

}

return0;

}

本程序中首先定义一个无返回值函数nzp,并说明其形参v为整型变量。在函数体中根据v值输出相应的结果。在main函数中用一个for语句输入数组各元素,每输入一个就以该元素作实参调用一次nzp函数,即把a[i]的值传送给形参v,供nzp函数使用。

数组名作为函数参数

用数组名作函数参数与用数组元素作实参有几点不同。1) 用数组元素作实参时,只要数组类型和函数的形参变量的类型一致,那么作为下标变量的数组元素的类型也和函数形参变量的类型是一致的。因此,并不要求函数的形参也是下标变量。换句话说,对数组元素的处理是按普通变量对待的。用数组名作函数参数时,则要求形参和相对应的实参都必须是类型相同的数组,都必须有明确的数组说明。当形参和实参二者不一致时,即会发生错误。2) 在普通变量或下标变量作函数参数时,形参变量和实参变量是由编译系统分配的两个不同的内存单元。在函数调用时发生的值传送是把实参变量的值赋予形参变量。在用数组名作函数参数时,不是进行值的传送,即不是把实参数组的每一个元素的值都赋予形参数组的各个元素。因为实际上形参数组并不存在,编译系统不为形参数组分配内存。那么,数据的传送是如何实现的呢?在我们曾介绍过,数组名就是数组的首地址。因此在数组名作函数参数时所进行的传送只是地址的传送,也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。

#include

floataver(floata[5]){

inti;

floatav,s=a[0];

for(i=1;i<5;i++)

s=s+a[i];

av=s/5;

returnav;

}

intmain(void){

floatsco[5],av;

inti;

printf("\ninput 5 scores:\n");

for(i=0;i<5;i++)

scanf("%f",&sco[i]);

av=aver(sco);

printf("average score is %5.2f",av);

return0;

}

本程序首先定义了一个实型函数aver,有一个形参为实型数组a,长度为5。在函数aver中,把各元素值相加求出平均值,返回给主函数。主函数main 中首先完成数组sco的输入,然后以sco作为实参调用aver函数,函数返回值送av,最后输出av值。 从运行情况可以看出,程序实现了所要求的功能。3) 前面已经讨论过,在变量作函数参数时,所进行的值传送是单向的。即只能从实参传向形参,不能从形参传回实参。形参的初值和实参相同,而形参的值发生改变后,实参并不变化,两者的终值是不同的。而当用数组名作函数参数时,情况则不同。由于实际上形参和实参为同一数组,因此当形参数组发生变化时,实参数组也随之变化。当然这种情况不能理解为发生了“双向”的值传递。但从实际情况来看,调用函数之后实参数组的值将由于形参数组值的变化而变化。为了说明这种情况,把【例5.4】改为【例5.6】的形式。【例8-9】题目同【例8.7】。改用数组名作函数参数。

#include

voidnzp(inta[5]){

inti;

printf("\nvalues of array a are:\n");

for(i=0;i<5;i++){

if(a[i]<0)a[i]=0;

printf("%d ",a[i]);

}

}

intmain(void){

intb[5],i;

printf("\ninput 5 numbers:\n");

for(i=0;i<5;i++)

scanf("%d",&b[i]);

printf("initial values of array b are:\n");

for(i=0;i<5;i++)

printf("%d ",b[i]);

nzp(b);

printf("\nlast values of array b are:\n");

for(i=0;i<5;i++)

printf("%d ",b[i]);

return0;

}

本程序中函数nzp的形参为整数组a,长度为5。主函数中实参数组b也为整型,长度也为5。在主函数中首先输入数组b的值,然后输出数组b的初始值。然后以数组名b为实参调用nzp函数。在nzp中,按要求把负值单元清0,并输出形参数组a的值。 返回主函数之后,再次输出数组b的值。从运行结果可以看出,数组b的初值和终值是不同的,数组b的终值和数组a是相同的。这说明实参形参为同一数组,它们的值同时得以改变。用数组名作为函数参数时还应注意以下几点:①形参数组和实参数组的类型必须一致,否则将引起错误。②形参数组和实参数组的长度可以不相同,因为在调用时,只传送首地址而不检查形参数组的长度。当形参数组的长度与实参数组不一致时,虽不至于出现语法错误(编译能通过),但程序执行结果将与实际不符,这是应予以注意的。【例8.10】如把例8.9修改如下:

#include

voidnzp(inta[8]){

inti;

printf("\nvalues of array aare:\n");

for(i=0;i<8;i++){

if(a[i]<0)a[i]=0;

printf("%d ",a[i]);

}

}

intmain(void){

intb[5],i;

printf("\ninput 5 numbers:\n");

for(i=0;i<5;i++)

scanf("%d",&b[i]);

printf("initial values of array b are:\n");

for(i=0;i<5;i++)

printf("%d ",b[i]);

nzp(b);

printf("\nlast values of array b are:\n");

for(i=0;i<5;i++)

printf("%d ",b[i]);

return0;

}

本程序与【例8.9】程序比,nzp函数的形参数组长度改为8,函数体中,for语句的循环条件也改为i<8。因此,形参数组a和实参数组b的长度不一致。编译能够通过,但从结果看,数组a的元素a[5]、a[6]、a[7]显然是无意义的。③在函数形参表中,允许不给出形参数组的长度,或用一个变量来表示数组元素的个数。例如,可以写为:    void nzp(int a[])或写为    void nzp( int a[], int n )其中形参数组a没有给出长度,而由n值动态地表示数组的长度。n的值由主调函数的实参进行传送。由此,【例8-10】又可改为【例8-11】的形式。【例8-11】

#include

voidnzp(inta[],intn){

inti;

printf("\nvalues of array a are:\n");

for(i=0;i

if(a[i]<0)a[i]=0;

printf("%d ",a[i]);

}

}

intmain(void){

intb[5],i;

printf("\ninput 5 numbers:\n");

for(i=0;i<5;i++)

scanf("%d",&b[i]);

printf("initial values of array b are:\n");

for(i=0;i<5;i++)

printf("%d ",b[i]);

nzp(b,5);

printf("\nlast values of array b are:\n");

for(i=0;i<5;i++)

printf("%d ",b[i]);

return0;

}

本程序nzp函数形参数组a没有给出长度,由n 动态确定该长度。在main函数中,函数调用语句为nzp(b,5),其中实参5将赋予形参n作为形参数组的长度。④多维数组也可以作为函数的参数。在函数定义时对形参数组可以指定每一维的长度,也可省去第一维的长度。因此,以下写法都是合法的:    int MA(int a[3][10])或    int MA(int a[][10])。

(0)

相关推荐

  • 如何利用R语言中的函数读取CSV文件中的内容

    R语言中的函数可以从CSV文件中读取文件内容,这个函数是read.table(),参数有文件名称.行头.第一列头标题和分隔符.下面利用一个实例说明读取csv文件内容,操作如下: 操作方法 01 第一步 ...

  • C语言数组的应用

    操作方法 01 C语言数组的应用 C语言一维数组的定义和引用 (一) 维数组的界说和引证 在程序设计中,为了处置便利,把具有一样类型的若干变量按有序的办法组织起来.这些按序摆放的同类数据元素的调集称为 ...

  • 如何使用R语言中的函数绘制正态曲线

    正态曲线是数学中的一种概率统计函数,用于统计分析数据.R语言中也有处理正态曲线的函数dnorm(),可以使用这个函数绘制正态曲线.下面利用一个实例说明这个函数的用法,操作如下: 操作方法 01 第一步 ...

  • PHP数组--排序函数

    有时候,一个php函数就能省去我们大量的代码,在写程序的时候,如果能灵活运用这些函数,将大大节省时间,提高效率,下面总结的是php常用的数组排序函数,phper一定会用到的. 操作方法 01 1.so ...

  • Javascript里有哪些常用的数组操作函数?

    在写JS(Javascript)代码时,我们经常会对数组进行各种操作.那么你知道JS有哪些常用的操作函数吗?下面来介绍一下,熟悉这些函数对我们平常开发有很大的帮助. 操作方法 01 首先我们看下数组的 ...

  • vba操作Excel之MsgBox函数参数详解

    一、函数语法 函数名称:MsgBox 函数功能:在对话框中显示消息,等待用户单击按钮,并返回一个 Integer 告诉用户单击哪一个按钮。 函数语法: MsgBox(prompt[, buttons] ...

  • excel2016怎么开启输入时提示函数参数功能?

    函数的参数很多如果输入的时候有提示会好很多,但是最近发现excel2016中函数不再显示提示信息了,该怎么解决呢?下面我们就来看看详细的教程. 1.首先打开要编辑的excel文档,可以看到在使用函数进 ...

  • 如何利用R语言中的函数方法获取标准差和平均值

    R语言中可以使用不同的方法获取数据的统计的值,如标准差.平均值和相关度等.其中,标准差是利用sd()函数,平均值是利用mean()函数,相关度是利用cor()函数.下面利用一个实例说明这三个函数的用法 ...

  • c语言之rand函数的使用

    c语言中的rand随机数函数,是按指定顺序来产生的,在生成随机数之前,在stdlib.h头文件中,会初始化函数srand,根据随机种子seed,来获取随机数,如果seed不变,每次运行得到的随机数会是 ...