第17讲 调用函数与被调用函数间的数据传递 函数的递归调用 程序举例 1.ppt

第17讲 调用函数与被调用函数间的数据传递 函数的递归调用 程序举例 1.ppt

  1. 1、本文档共30页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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

文档评论(0)

kehan123 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档