- 1、本文档共30页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第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
您可能关注的文档
- 国民经济账户体系与矩阵表.ppt
- 第13篇 数据库开发方法.ppt
- 国内轻型越野汽车用变速器的现状及发展趋势.pdf
- 第13篇 Recordset对象-存取数据库的对象.ppt
- 计算机导论之程序设计和数据结构.ppt
- 计算机二级VB填空题及选择题10.doc
- 第13篇 开发Web应用程序.ppt
- 计算机基础 第3节 真题整理.doc
- 第13篇 输入输出流.ppt
- 计算机接口技术及应用 第3讲 (地址空间及译码) (2010秋).pdf
- 《JJF 2132-2024荧光紫外灯人工气候老化试验装置校准规范:辐射照度参数》.pdf
- JJF 2120-2024轮速传感器校准规范.pdf
- 计量规程规范 JJF 2120-2024轮速传感器校准规范.pdf
- 《JJF 2129-2024钙钛矿太阳电池校准规范:光电性能参数》.pdf
- JJF 2129-2024钙钛矿太阳电池校准规范:光电性能参数.pdf
- 《JJF 2120-2024轮速传感器校准规范》.pdf
- JJF 2117-2024沥青混合料理论最大相对密度仪校准规范.pdf
- JJF 2116-2024特定蛋白分析仪校准规范.pdf
- 《JJF 2116-2024特定蛋白分析仪校准规范》.pdf
- 计量规程规范 JJF 2117-2024沥青混合料理论最大相对密度仪校准规范.pdf
文档评论(0)