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

  • 1
  • 0
  • 约 30页
  • 2017-07-17 发布于四川
  • 举报

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

第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)

1亿VIP精品文档

相关文档