- 1
- 0
- 约 30页
- 2017-07-17 发布于四川
- 举报
第17讲;形参与实参的概念
形式参数:定义函数时函数名后面括号中的变量名
实际参数:调用函数时函数名后面括号中的表达式;(1) 实参表达式也可以是变量或常量,但必须有确定的值;
(2) 要求形参与实参类型一致,个数相同(多:略/少:随机值);
(4) 形参在函数被调用前不占内存;函数调用时为形参分配内存;调用结束,内存释放;
(5) C语言的参数传递方式
值传递方式:函数调用时,系统临时为被调函数的形参分配存贮单元,并将实参的值复制到形参中;当被调函数结束时,形参单元被释放,实参单元仍保留并维持原值。
特点:单向的值传递(数值或地址值)。;x;main()
{void swap(int , int);
int x=10,y=20;
printf(“(1)x=%d y=%d\n”,x,y);
swap(x,y);
printf(“(4)x=%d y=%d\n”,x,y);
}
void swap(int a, int b)
{int t;
printf(“(2)a=%d b=%d\n”,a,b);
t=a; a=b; b=t;
printf(“(3)a=%d b=%d\n”,a,b);
};main( )
{void ex(int z,int y,int x);
int x=10,y=20,z=30;
printf(“(1)x=%d y=%d z=%d\n”,x,y,z);
ex(y,z,x);
}
void ex(int x,int y,int z)
{
printf(“(2)x=%d y=%d z=%d\n”,x,y,z);
};#include stdio.h
long sum(int a, int b);
long factorial(int n);
void main()
{ int n1,n2;
long a;
scanf(%d,%d,n1,n2);
a=sum(n1,n2);
printf(a=%1d,a);
}
long sum(int a,int b)
{
long c1,c2;
c1=factorial(a);
c2=factorial(b);
return(c1+c2);
}; 当数组名作为函数参数时,要求实参和形参都用数组名(或指针变量,第十章作介绍)。
由于数组名的值就是数组在内存中分配的存储空间的首地址,这种方法称之为“传址调用”方式。
当把实参数组名的值(首地址)传给形参数组名后,由于形参数组名也代表首地址,这样实参数组和形参数组的首地址相同,即实参数组和形参数组占用相同的存储空间。在被调函数中,形参数组中各元素的值如果发生变化,就会使实参数组元素的值同时也发生变化。在函数调用结束后,虽然形参数组已不复存在,但实参数组元素的值已发生变化,可以在主调函数中进行使用。;例7.3 选择法排序 ;对10个数排序的算法步骤演示如下:;对10个数排序的算法步骤演示如下:;10个数排序的完整程序如下:;例7.4 将一个数组中的n个数据按颠倒的顺序重新存放 ;数组逆序程序;例7.5 求二维数组每行元素的平均值 ;main( );#include stdio.h
int dif(int x,int y,int z);
int max(int x,int y,int z);
int min(int x,int y,int z);
void main()
{int a,b,c,d;
scanf(%d%d%d,a,b,c);
d=dif(a,b,c);
printf(Max-Min=%d\n,d);
};例 用弦截法求方程根;求两点连线与x轴的交点x;2.递归调用
定义:函数直接或间接的调用自身叫函数的递归调用;#include stdio.h
int fac(int n)
{ int f;
if(n==0||n==1) f=1;
else f= fac(n-1)*n;
return(f );
}
main()
{ int n, y;
printf(Input a integer number:);
scanf(%d,n);
y=fac(n);
printf(%d!=%15d,n,y);
};#include stdio.h
int fib(int n)
{ int f;
if(n==1||n==2) f=1;
else f= fib(n-2)+fib(n-1
原创力文档

文档评论(0)