变量作为函数的参数进行传递.ppt_第1页
变量作为函数的参数进行传递.ppt_第2页
变量作为函数的参数进行传递.ppt_第3页
变量作为函数的参数进行传递.ppt_第4页
变量作为函数的参数进行传递.ppt_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

单元二 变量作为函数的参数进行传递 1、普通变量作为函数的参数进行传递,1.1 函数参数及其传递方式 形参与实参 形式参数:定义函数时函数名后面括号中的变量名 实际参数:调用函数时函数名后面括号中的表达式,例 比较两个数并输出大者,main() int a,b,c; scanf(“%d,%d“, ,1、 main() 2、 int a,b; 3、 int c; 4、 a=3;b=23; 5、 c=sum(a,b); 6、 printf(“sum is %dn“,c); 7、,int sum(int x, int y ) int z; z=x+y; return(z); ,x=a,3,23,y=b,等价于z=3+23;,等价于sum=z;,int sum(int x, int y) int z; z=x+y; return(z); main() int a,b; int c; a=3;b=23; c=sum(a,b); printf(“sum is %dn“,c); ,1.2 函数参数及其传递方式 形参与实参,1、实参必须有确定的值,说明:,main() int a,b,c; scanf(“%d,%d“, ,sum(int x, int y) int z; z=x+y; return(z); ,main() int a,b,c; a=23;b=24; c=sum(a,b); printf(“sum is %d“,c); ,2、形参必须指定类型,int sum(int x, int y) int z; z=x+y; return(z); ,int x,int y,3、形参与实参类型一致,个数相同,sum(int x, int y,float z) int d; d=x+y+z; return(d); main() int a,b,c; a=23;b=34; c=sum(a,b); printf(“sum is %d“,c); ,sum(int x, int y,float z) int d; d=x+y+z; return(d); main() int a=23,b=34,c,f; c=sum(a,b,f); printf(“sum is %d“,c); ,4、形参在函数被调用前不占存储空间;函数调用时为形参分配存储空间;调用结束,空间释放。,main() int a,b,c; a=23;b=34; sum(a,b); printf(“sum is %d“,c); sum(int x, int y) int z; z=x+y; return(z); ,a,b,c,23,34,x,y,z,c=,23,34,57,回收空间,回收空间,回收空间,回收空间,回收空间,回收空间,main() int a,b,c; a=23;b=34; c=sum(a,b); printf(“sum is %d“,c); sum(int x, int y) int z; z=x+y; return(z); ,57,5、如果实参是变量,则实参和形参的名字可以相同也可以不同,互不影响,因为它们存储数据的空 间不同。,main() int a,b,c; a=23;b=34; sum(a,b); printf(“sum is %d“,c); sum(int a, int b) int z; z=a+b; return(z); ,a,b,c,23,34,a,b,z,c=,23,34,57,回收空间,回收空间,回收空间,回收空间,回收空间,回收空间,main() int a,b,c; a=23;b=34; c=sum(a,b); printf(“sum is %d“,c); sum(int a, int b) int z; z=a+b; return(z); ,57,例 1计算x的立方,#include float c(float x) return(x*x*x); main() float a, p; printf(“Please input value of a:“); scanf(“%f“, ,x,a,p,1.2,1.2,1.728,内存的变化情况,1.3参数传递方式 值传递方式 方式:函数调用时,为形参分配单元,并将实参的值复制到形参中;调用结束,形参单元被释放,实参单元仍保留并维持原值 特点: 形参与实参占用不同的内存单元 单向传递 实参可以是常量、变量或表达式,但必须有确定的值。,例 2交换两个数,#include main() int x=7,y=11; swap(x,y); printf(“%d,%dn“,a,b); void swap(int a,int b) int temp; temp=a; a=b; b=temp; printf(“a=%d,b=%d”,a,b) ,1、用函数实现如下题目: 相传古代印度国王舍罕要褒奖他的聪明能干的宰相达依尔(国际象棋发明者),问他需要什么,达依尔回答说:“国王只要在国际象棋的棋盘上第一个格子放一粒麦子,第二格子放上两粒,第三个格子放上四粒,依次类推,每一格子的麦子数是前一格子的两倍,一直放到64格,我就感恩不尽了”。国王答应了,结果全印度的粮食用完还不够。国王很那纳闷,怎末也算不清这笔账。(1m2大约为1.42108粒小麦)其中将2n 的求解采用函数模块编写。,函数定义、声明、调用实训练习,2、3个同学进行踢毽子比赛,编写函数,求出踢的个数最多和最少的差。 提示:编写两个函数,分别用于求3个数的最大值和最小值。然后再编写一个函数,调用最大值和最小值函数求差,将求差的结果返回。 3、编写函数: 求2个数的加、减、乘、除以及余数。,4、利用函数实现如下程序: 输出n!的低2位的值,例如:5!=120 输 出20 5、利用函数实现如下题目: 计算50以内所有能被3整出的数的倒数之积。 6、利用函数实现如下题目: 计算s=12!+ 22! + 32!+n2!,练习,7、利用函数求和,练习,8、利用函数编写程序求出斐波那契数列的第n项 斐波那契数列可以用递推公式来表示: F1=1 F2=1 Fn=Fn-1+Fn-2,练习,9、编写

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论