ImageVerifierCode 换一换
格式:PPT , 页数:254 ,大小:3.20MB ,
资源ID:10069309      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-10069309.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(第7章 用函数实现模块化程序设计.ppt)为本站会员(hwpkd79526)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

第7章 用函数实现模块化程序设计.ppt

1、1/211,第7章 用函数实现模块化程序设计,7.1为什么要用函数 7.2怎样定义函数 7.3调用函数 7.4对被调用函数的声明和函数原型 7.5函数的嵌套调用 7.6函数的递归调用 7.7数组作为函数参数 7.8局部变量和全局变量 7.9变量的存储方式和生存期 7.10 关于变量的声明和定义 7.11 内部函数和外部函数,2/211,7.1为什么要用函数,问题: 如果程序的功能比较多,规模比较大,把所有代码都写在main函数中,就会使主函数变得庞杂、头绪不清,阅读和维护变得困难 有时程序中要多次实现某一功能,就需要多次重复编写实现此功能的程序代码,这使程序冗长,不精炼,3/211,7.1为什

2、么要用函数,解决的方法:用模块化程序设计的思路 采用“组装”的办法简化程序设计的过程 事先编好一批实现各种不同功能的函数 把它们保存在函数库中,需要时直接用,4/211,7.1为什么要用函数,解决的方法:用模块化程序设计的思路 函数就是功能 每一个函数用来实现一个特定的功能 函数的名字应反映其代表的功能,5/211,7.1为什么要用函数,在设计一个较大的程序时,往往把它分为若干个程序模块,每一个模块包括一个或多个函数,每个函数实现一个特定的功能 程序可由一个主函数和若干个其他函数构成 主函数调用其他函数,其他函数也可以互相调用 同一个函数可以被一个或多个函数调用任意多次,6/211,7.1为什

3、么要用函数,main,a,b,c,f,g,h,d,e,i,e,7/211,7.1为什么要用函数,可以使用库函数 可以使用自己编写的函数 在程序设计中要善于利用函数,可以减少重复编写程序段的工作量,同时可以方便地实现模块化的程序设计,8/211,C+程序是函数驱动的. 无论把一个程序(项目)划分为多少个程序模块,只能有一个main函数. 在实际应用的程序中,主函数写得很简单,它的作用就是调用各个函数,相当于总调度,调动各函数依次实现各项功能. 要善于利用库函数,以减少重复编写程序段的工作量. 函数定义不能嵌套,但函数调用可以嵌套.,9/211,分类 按用户使用的角度分 系统函数,即库函数 用户自

4、定义的函数 按函数的形式分 有参函数 无参函数 按返回值分 有返回值函数 无返回值函数,10/211,11/211,7.1为什么要用函数,例7.1 输出以下的结果,用函数调用实现。*How do you do!*,12/211,7.1为什么要用函数,解题思路: 在输出的文字上下分别有一行“*”号,显然不必重复写这段代码,用一个函数print_star来实现输出一行“*”号的功能。 再写一个print_message函数来输出中间一行文字信息 用主函数分别调用这两个函数,13/211,#include int main() void print_star(); void print_messag

5、e(); print_star(); print_message(); print_star(); return 0; ,void print_star() printf(“*n”); ,void print_message() printf(“ How do you do!n”); ,输出16个*,输出一行文字,14/211,#include int main() void print_star(); void print_message(); print_star(); print_message(); print_star(); return 0; ,void print_star()

6、printf(“*n”); ,void print_message() printf(“ How do you do!n”); ,声明函数,定义函数,15/211,#include int main() void print_star(); void print_message(); print_star(); print_message(); print_star(); return 0; ,void print_star() printf(“*n”); ,void print_message() printf(“ How do you do!n”); ,16/211,7.2 怎样定义函数,

7、7.2.1 为什么要定义函数 7.2.2 定义函数的方法,17/211,7.2.1 为什么要定义函数,C语言要求,在程序中用到的所有函数,必须“先定义,后使用” 指定函数名字、函数返回值类型、函数实现的功能以及参数的个数与类型,将这些信息通知编译系统。,18/211,7.2.1 为什么要定义函数,指定函数的名字,以便以后按名调用 指定函数类型,即函数返回值的类型 指定函数参数的名字和类型,以便在调用函数时向它们传递数据 指定函数的功能。这是最重要的,这是在函数体中解决的,19/211,7.2.1 为什么要定义函数,对于库函数,程序设计者只需用#include指令把有关的头文件包含到本文件模块中

8、即可 程序设计者需要在程序中自己定义想用的而库函数并没有提供的函数,20/211,7.2.2 定义函数的方法,1.定义无参函数 定义无参函数的一般形式为:,类型名 函数名(void) 函数体 ,类型名 函数名() 函数体 ,包括声明部分和语句部分,包括声明部分和语句部分,21/211,7.2.2 定义函数的方法,1.定义无参函数 定义无参函数的一般形式为:,类型名 函数名(void) 函数体 ,类型名 函数名() 函数体 ,指定函数值的类型,指定函数值的类型,22/211,7.2.2 定义函数的方法,2.定义有参函数 定义有参函数的一般形式为: 类型名 函数名(形式参数表列) 函数体,23/2

9、11,7.2.2 定义函数的方法,3. 定义空函数 定义空函数的一般形式为: 类型名 函数名( ) 先用空函数占一个位置,以后逐步扩充 好处:程序结构清楚,可读性好,以后扩充新功能方便,对程序结构影响不大,24/211,7.3 调用函数,7.3.1函数调用的形式 7.3.2函数调用时的数据传递 7.3.3函数调用的过程 7.3.4函数的返回值,25/211,7.3.1函数调用的形式,函数调用的一般形式为:函数名(实参表列) 如果是调用无参函数,则“实参表列”可以没有,但括号不能省略 如果实参表列包含多个实参,则各参数间用逗号隔开,26/211,7.3.1函数调用的形式,按函数调用在程序中出现的

10、形式和位置来分,可以有以下3种函数调用方式: . 函数调用语句 把函数调用单独作为一个语句如printf_star(); 这时不要求函数带回值,只要求函数完成一定的操作,27/211,7.3.1函数调用的形式,按函数调用在程序中出现的形式和位置来分,可以有以下3种函数调用方式: . 函数调用表达式 函数调用出现在另一个表达式中如c=max(a,b); 这时要求函数带回一个确定的值以参加表达式的运算,28/211,7.3.1函数调用的形式,按函数调用在程序中出现的形式和位置来分,可以有以下3种函数调用方式: . 函数参数 函数调用作为另一函数调用时的实参如mmax(a,max(b,c); 其中m

11、ax(b,c)是一次函数调用,它的值作为max另一次调用的实参,29/211,7.3.2 函数调用时的数据传递,1. 形式参数和实际参数 在定义函数时函数名后面括号中的变量名称为形式参数或虚拟参数(formal parameter,简称形参).在主调函数中调用一个函数时,函数名后面括号中的参数(可以是一个表达式)称为实际参数 (actual parameter,简称实参).,30/211,7.3.2 函数调用时的数据传递,2. 实参和形参间的数据传递 在调用函数过程中,系统会把实参的值传递给被调用函数的形参 或者说,形参从实参得到一个值 该值在函数调用期间有效,可以参加被调函数中的运算,参数传

12、递方式: 1、传值(单向) 2、传地址(双向) 3、传引用(双向),31/211,7.3.2 函数调用时的数据传递,例7.2 输入两个整数,要求输出其中值较大者。要求用函数来找到大数。 解题思路: (1)函数名应是见名知意,今定名为max (2) 由于给定的两个数是整数,返回主调函数的值(即较大数)应该是整型 (3)max函数应当有两个参数,以便从主函数接收两个整数,因此参数的类型应当是整型,32/211,7.3.2 函数调用时的数据传递,先编写max函数: int max(int x,int y) int z; z=xy?x:y; return(z); ,33/211,7.3.2 函数调用时

13、的数据传递,在max函数上面,再编写主函数 #include int main() int max(int x,int y); int a,b,c; printf(“two integer numbers: “); scanf(“%d,%d”, ,实参可以是常量、变量或表达式,34/211,7.3.2 函数调用时的数据传递,c=max(a,b); (main函数)int max(int x, int y) (max函数) int z; z=xy?x:y; return(z); ,传值,35/211,说明:在发生函数调用时,形参才被分配存储单元.实参与形参的类型应匹配.实参可以是常量,变量或表达

14、式.,即一致或赋值兼容,36/211,7.3.2 函数调用时的数据传递,在定义函数中指定的形参,在未出现函数调用时,它们并不占内存中的存储单元。在发生函数调用时,函数max的形参被临时分配内存单元。,2,a,3,b,x,y,2,3,实参,形参,37/211,7.3.2 函数调用时的数据传递,调用结束,形参单元被释放 实参单元仍保留并维持原值,没有改变 如果在执行一个被调用函数时,形参的值发生改变,不会改变主调函数的实参的值,2,a,3,b,x,y,2,3,实参,形参,(传值),38/211,7.3.3 函数调用的过程,函数调用机制: 建立被调函数的栈空间; 保护调用函数的运行状态和返回地址;

15、传递参数; 将控制转交被调函数.,39/211,函数调用机制,40/211,7.3.4. 函数的返回值,函数的返回值是通过函数中的return语句获得的; return语句将被调用函数中的一个确定值带回主调函数;return语句后面的括号有时可省;return后面的值可以是一个表达式;一个函数中可以有多个return语句,但只执行其中一个. 函数的返回值应与函数定义时给定的数据类型匹配(必要时进行自动类型转换).,41/211,7.3.4. 函数的返回值,例7.3将例7.2稍作改动,将在max函数中定义的变量z改为float型。函数返回值的类型与指定的函数类型不同,分析其处理方法。 解题思路:

16、如果函数返回值的类型与指定的函数类型不同,按照赋值规则处理。,42/211,#include int main() int max(float x,float y);float a,b; int c;scanf(“%f,%f,“, ,1.5,2.6,2.6,2,变为2,43/211,7.4对被调用函数的声明和函数原型,在一个函数中调用另一个函数需要具备如下条件: (1) 被调用函数必须是已经定义的函数(是库函数或用户自己定义的函数) (2) 如果使用库函数,应该在本文件开头加相应的#include指令 (3) 如果使用自己定义的函数,而该函数的位置在调用它的函数后面,应该声明,44/211,7

17、.4对被调用函数的声明和函数原型,例7.4 输入两个实数,用一个函数求出它们之和。 解题思路:用add函数实现。首先要定义add函数,它为float型,它应有两个参数,也应为float型。特别要注意的是:要对add函数进行声明。,45/211,7.4对被调用函数的声明和函数原型,分别编写add函数和main函数,它们组成一个源程序文件 main函数的位置在add函数之前 在main函数中对add函数进行声明,46/211,#include int main() float add(float x, float y); float a,b,c;printf(“Please enter a and

18、 b:“); scanf(“%f,%f“, ,float add(float x,float y) float z; z=x+y;return(z); ,求两个实数之和,函数值也是实型,对add函数声明,47/211,#include int main() float add(float x, float y); float a,b,c;printf(“Please enter a and b:“); scanf(“%f,%f“, ,float add(float x,float y) float z; z=x+y;return(z); ,只差一个分号,48/211,#include int

19、main() float add(float x, float y); float a,b,c;printf(“Please enter a and b:“); scanf(“%f,%f“, ,float add(float x,float y) float z; z=x+y;return(z); ,定义add函数,调用add函数,49/211,函数原型的一般形式有两种: 如 float add(float x, float y);float add(float, float); 原型说明可以放在文件的开头,这时所有函数都可以使用此函数,50/211,7.5 函数的嵌套调用,语言的函数定义是互

20、相平行、独立的 即函数定义不能嵌套 但函数调用可以嵌套 即调用一个函数的过程中,又可以调用另一个函数,51/211,7.5 函数的嵌套调用,main函数,调用a函数,结束,a函数,调用b函数,b函数,52/211,7.5 函数的嵌套调用,例7.5 输入4个整数,找出其中最大的数。用函数的嵌套调用来处理。 解题思路: main中调用max4函数,找4个数中最大者 max4中再调用max2,找两个数中的大者 max4中多次调用max2,可找4个数中的大者,然后把它作为函数值返回main函数 main函数中输出结果,53/211,#include int main() int max4(int a,

21、int b,int c,int d); int a,b,c,d,max;printf(“4 interger numbers:“); scanf(“%d%d%d%d“, ,主函数,对max4 函数声明,54/211,#include int main() int max4(int a,int b,int c,int d); int a,b,c,d,max;printf(“4 interger numbers:“); scanf(“%d%d%d%d“, ,主函数,输入4个整数,55/211,#include int main() int max4(int a,int b,int c,int d)

22、; int a,b,c,d,max;printf(“4 interger numbers:“); scanf(“%d%d%d%d“, ,主函数,调用后肯定是4个数中最大者,输出最大者,56/211,int max4(int a,int b,int c,int d) int max2(int a,int b); int m; m=max2(a,b); m=max2(m,c); m=max2(m,d); return(m); ,max4函数,对max2 函数声明,57/211,int max4(int a,int b,int c,int d) int max2(int a,int b); int

23、m; m=max2(a,b); m=max2(m,c); m=max2(m,d); return(m); ,max4函数,a,b中较大者,a,b,c中较大者,a,b,c,d中最大者,58/211,int max4(int a,int b,int c,int d) int max2(int a,int b); int m; m=max2(a,b); m=max2(m,c); m=max2(m,d); return(m); ,max4函数,int max2(int a,int b) if(a=b)return a; else return b; ,max2函数,找a,b中较大者,59/211,in

24、t max4(int a,int b,int c,int d) int max2(int a,int b); int m; m=max2(a,b); m=max2(m,c); m=max2(m,d); return(m); ,max4函数,int max2(int a,int b) if(a=b)return a; else return b; ,max2函数,return(ab?a:b);,60/211,int max4(int a,int b,int c,int d) int max2(int a,int b); int m; m=max2(a,b); m=max2(m,c); m=max

25、2(m,d); return(m); ,max4函数,int max2(int a,int b) return(ab?a:b); ,61/211,int max4(int a,int b,int c,int d) int max2(int a,int b); int m; m=max2(a,b); m=max2(m,c); m=max2(m,d); return(m); ,max4函数,m=max2(max2(a,b),c);,int max2(int a,int b) return(ab?a:b); ,62/211,int max4(int a,int b,int c,int d) int

26、max2(int a,int b); int m; m=max2(a,b); m=max2(m,c); m=max2(m,d); return(m); ,max4函数,m=max2(max2(max2(a,b),c),d);,int max2(int a,int b) return(ab?a:b); ,63/211,int max4(int a,int b,int c,int d) int max2(int a,int b); int m; m=max2(a,b); m=max2(m,c); m=max2(m,d); return(m); ,max4函数,ruturn max2(max2(ma

27、x2(a,b),c),d);,int max2(int a,int b) return(ab?a:b); ,64/211,int max4(int a,int b,int c,int d) int max2(int a,int b); ruturn max2(max2(max2(a,b),c),d); ,int max2(int a,int b) return(ab?a:b); ,#include int main() max=max4(a,b,c,d); ,65/211,1.什么是递归函数(recursive function),又称为自调用函数,即函数嵌套调用该函数本身.,7.6 函数的递

28、归调用,66/211,2.函数调用机制的说明被调函数运行的代码虽是同一个函数的代码体,但由于调用点,调用时状态,返回点的不同,可以看作是函数的一个副本,与调用函数的代码无关,即函数的代码是独立的.被调函数运行的栈空间独立于调用函数的栈空间,所以与调用函数之间的数据也是无关的.函数之间靠参数传递和返回值来联系,函数看作为黑盒.,67/211,3.递归调用的形式,68/211,4.递归函数的组成必须有完成函数任务的语句,即递归体,其中包括至少一个递归调用语句; 一个递归终止条件,即递归出口.,69/211,7.6 函数的递归调用,例7.6 有5个学生坐在一起 问第5个学生多少岁?他说比第4个学生大

29、2岁 问第4个学生岁数,他说比第3个学生大2岁 问第3个学生,又说比第2个学生大2岁 问第2个学生,说比第1个学生大2岁 最后问第1个学生,他说是10岁 请问第5个学生多大,70/211,7.6 函数的递归调用,解题思路: 要求第个年龄,就必须先知道第个年龄 要求第个年龄必须先知道第个年龄 第个年龄又取决于第个年龄 第个年龄取决于第个年龄 每个学生年龄都比其前个学生的年龄大,71/211,7.6 函数的递归调用,解题思路: age(5)=age(4)+2 age(4)=age(3)+2 age(3)=age(2)+2 age(2)=age(1)+2 age(1)=10,72/211,age(5

30、) =age(4)+2,age(4) =age(3)+2,age(3) =age(2)+2,age(2) =age(1)+2,age(1)=10,age(2)=12,age(3)=14,age(4)=16,age(5)=18,递推阶段,回溯阶段,73/211,age(5) =age(4)+2,age(4) =age(3)+2,age(3) =age(2)+2,age(2) =age(1)+2,age(1)=10,age(2)=12,age(3)=14,age(4)=16,age(5)=18,递推阶段,回溯阶段,结束递归的条件,74/211,#include int main() int age

31、(int n);printf(“NO.5,age:%dn“,age(5); return 0; int age(int n) int c; if(n=1) c=10; else c=age(n-1)+2; return(c); ,75/211,age(5) 输出age(5),main,c=age(4)+2,age函数 n=5,c=age(3)+2,age函数 n=4,c=age(1)+2,age函数 n=2,c=age(2)+2,age函数 n=3,c=10,age函数 n=1,age(1)=10,age(2)=12,age(3)=14,age(4)=16,age(5)=18,18,76/21

32、1,例7.7 用递归方法求!。 解题思路: 求!可以用递推方法:即从开始,乘,再乘一直乘到。 递推法的特点是从一个已知的事实(如1!=1)出发,按一定规律推出下一个事实(如2!=1!*2),再从这个新的已知的事实出发,再向下推出一个新的事实(3!=3*2!)。n!=n*(n-1)!。,77/211,例7.7 用递归方法求!。 解题思路: 求!也可以用递归方法,即!等于!,而!,! 可用下面的递归公式表示:,78/211,#include int main()int fac(int n); int n; int y;printf(“input an integer number:“);scanf

33、(“%d“, ,79/211,int fac(int n) int f;if(n0) printf(“n0,data error!“);else if(n=0 | | n=1)f=1;else f=fac(n-1)*n; return(f);,注意溢出,80/211,fac(5) 输出fac(5),main,f=fac(4)5,fac函数 n=5,f=fac(3)4,fac函数 n=4,f=fac(1)2,fac函数 n=2,f=fac(2)3,fac函数 n=3,f=1,fac函数 n=1,fac(1)=1,fac(2)=2,fac(3)=6,fac(4)=24,fac(5)=120,120

34、,81/211,例7.8 Hanoi(汉诺)塔问题。古代有一个梵塔,塔内有3个座A、B、C,开始时座上有64个盘子,盘子大小不等,大的在下,小的在上。有一个老和尚想把这64个盘子从座移到座,但规定每次只允许移动一个盘,且在移动过程中在3个座上都始终保持大盘在下,小盘在上。在移动过程中可以利用B座。要求编程序输出移动盘子的步骤。,82/211,83/211,解题思路: 要把64个盘子从A座移动到C座,需要移动大约264 次盘子。一般人是不可能直接确定移动盘子的每一个具体步骤的 老和尚会这样想:假如有另外一个和尚能有办法将上面63个盘子从一个座移到另一座。那么,问题就解决了。此时老和尚只需这样做:

35、,84/211,解题思路: (1) 命令第2个和尚将63个盘子从A座移到B座 (2) 自己将1个盘子(最底下的、最大的盘子)从A座移到C座 (3) 再命令第2个和尚将63个盘子从B座移到C座,85/211,A,B,C,将63个从A到B,第1个和尚的做法,86/211,A,B,C,将63个从A到B,第1个和尚的做法,87/211,A,B,C,将1个从A到C,第1个和尚的做法,88/211,A,B,C,将1个从A到C,第1个和尚的做法,89/211,A,B,C,将63个从B到C,第1个和尚的做法,90/211,A,B,C,将63个从B到C,第1个和尚的做法,91/211,A,B,C,将62个从A到

36、C,第2个和尚的做法,92/211,A,B,C,将62个从A到C,第2个和尚的做法,93/211,A,B,C,将1个从A到B,第2个和尚的做法,94/211,A,B,C,将1个从A到B,第2个和尚的做法,95/211,A,B,C,将62个从C到B,第2个和尚的做法,96/211,A,B,C,将62个从C到B,第2个和尚的做法,97/211,第3个和尚的做法 第4个和尚的做法 第5个和尚的做法 第6个和尚的做法 第7个和尚的做法 第63个和尚的做法,第64个和尚仅做:将1个从A移到C,98/211,A,B,C,将3个盘子从A移到C的全过程,将2个盘子从A移到B,99/211,A,B,C,将3个盘

37、子从A移到C的全过程,将2个盘子从A移到B,100/211,A,B,C,将3个盘子从A移到C的全过程,将1个盘子从A移到C,101/211,A,B,C,将3个盘子从A移到C的全过程,将1个盘子从A移到C,102/211,A,B,C,将3个盘子从A移到C的全过程,将2个盘子从B移到C,103/211,A,B,C,将3个盘子从A移到C的全过程,将2个盘子从B移到C,104/211,A,B,C,将2个盘子从A移到B的过程,将1个盘子从A移到C,105/211,A,B,C,将2个盘子从A移到B的过程,将1个盘子从A移到C,106/211,A,B,C,将2个盘子从A移到B的过程,将1个盘子从A移到B,1

38、07/211,A,B,C,将2个盘子从A移到B的过程,将1个盘子从A移到B,108/211,A,B,C,将2个盘子从A移到B的过程,将1个盘子从C移到B,109/211,A,B,C,将2个盘子从A移到B的过程,将1个盘子从C移到B,110/211,A,B,C,将2个盘子从B移到C的过程,111/211,A,B,C,将2个盘子从B移到C的过程,112/211,A,B,C,将2个盘子从B移到C的过程,113/211,A,B,C,将2个盘子从B移到C的过程,114/211,由上面的分析可知:将n个盘子从A座移到C座可以分解为以下3个步骤: (1) 将A上n-1个盘借助C座先移到B座上 (2) 把A座

39、上剩下的一个盘移到C座上 (3) 将n-1个盘从B座借助于座移到C座上,115/211,可以将第(1)步和第(3)步表示为: 将“one”座上n-1个盘移到“two”座(借助“three”座)。 在第(1)步和第(3)步中,one 、two、three和A、B、C的对应关系不同。 对第(1)步,对应关系是one对应A,two对应B,three对应C。 对第(3)步,对应关系是one对应B,two对应C,three对应A。,116/211,把上面3个步骤分成两类操作: (1) 将n-1个盘从一个座移到另一个座上(n1)。这就是大和尚让小和尚做的工作,它是一个递归的过程,即和尚将任务层层下放,直到

40、第64个和尚为止。 (2) 将1个盘子从一个座上移到另一座上。这是大和尚自己做的工作。,117/211,编写程序。 用hanoi函数实现第1类操作(即模拟小和尚的任务) 用move函数实现第2类操作(模拟大和尚自己移盘) 函数调用hanoi(n,one,two.three)表示将n个盘子从“one”座移到“three”座的过程(借助“two”座) 函数调用move(x,y)表示将1个盘子从x 座移到y 座的过程。x和y是代表A、B、C座之一,根据每次不同情况分别取A、B、C代入,118/211,#include int main() void hanoi(int n,char one,char

41、 two,char three); int m;printf(“the number of diskes:“);scanf(“%d“, ,119/211,void hanoi(int n,char one,char two,char three) void move(char x,char y); if(n=1)move(one,three);else hanoi(n-1,one,three,two);move(one,three);hanoi(n-1,two,one,three);,120/211,void move(char x,char y) printf(“%c%cn“,x,y);,典

42、型递归问题: 1、八皇后问题 2、迷宫问题,121/211,7.7数组作为函数参数,7.7.1数组元素作函数实参 7.7.2数组名作函数参数 7.7.3多维数组名作函数参数,122/211,7.7.1数组元素作函数实参,例7.9 输入10个数,要求输出其中值最大的元素和该数是第几个数。,123/211,7.7.1数组元素作函数实参,解题思路: 定义数组a,用来存放10个数 设计函数max,用来求两个数中的大者 在主函数中定义变量m,初值为a0,每次调用max函数后的返回值存放在m中 用“打擂台”算法,依次将数组元素a1到a9与m比较,最后得到的m值就是10个数中的最大者,124/211,#in

43、clude int main() int max(int x,int y); int a10,m,n,i;printf(“10 integer numbers:n“);for(i=0;i10;i+) scanf(“%d“,125/211,for(i=1,m=a0,n=0;im) m=max(m,ai); n=i; printf(“largest number is %dn“,m);printf(“%dth number.n“,n+1); ,int max(int x,int y) return(xy?x:y); ,126/211,7.7.2数组名作函数参数,除了可以用数组元素作为函数参数外,还

44、可以用数组名作函数参数(包括实参和形参) 用数组元素作实参时,向形参变量传递的是数组元素的值 用数组名作函数实参时,向形参传递的是数组首元素的地址,127/211,7.7.2数组名作函数参数,例7.10 有一个一维数组score,内放10个学生成绩,求平均成绩。 解题思路: 用函数average求平均成绩,用数组名作为函数实参,形参也用数组名 在average函数中引用各数组元素,求平均成绩并返回main函数,128/211,#include int main() float average(float array10); float score10,aver; int i;printf(“i

45、nput 10 scores:n“);for(i=0;i10;i+)scanf(“%f“, ,定义实参数组,129/211,float average(float array10) int i;float aver,sum=array0;for(i=1;i10;i+)sum=sum+arrayi; aver=sum/10;return(aver); ,定义形参数组,相当于score0,相当于scorei,可以省略,130/211,例7.11 有两个班级,分别有35名和30名学生,调用一个average函数,分别求这两个班的学生的平均成绩。,131/211,解题思路: 需要解决怎样用同一个函数求

46、两个不同长度的数组的平均值的问题 定义average函数时不指定数组的长度,在形参表中增加一个整型变量n 从主函数把数组实际长度从实参传递给形参n 这个n用来在average函数中控制循环的次数 为简化,设两个班的学生数分别为5和10,132/211,#include int main() float average(float array ,int n);float score15=98.5,97,91.5,60,55; float score210=67.5,89.5,99,69.5,77,89.5,76.5,54,60,99.5; printf(“%6.2fn”,average(scor

47、e1,5); printf(“%6.2fn”,average(score2,10); return 0; ,133/211,float average(float array ,int n) int i;float aver,sum=array0;for(i=1;in;i+)sum=sum+arrayi; aver=sum/n;return(aver); ,调用形式为average(score1,5)时,相当于score10,相当于score1i,相当于5,134/211,float average(float array ,int n) int i;float aver,sum=array0;for(i=1;in;i+)sum=sum+arrayi; aver=sum/n;return(aver); ,

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报