C语言程序设计教程教程C语言第6章函数.pptVIP

C语言程序设计教程教程C语言第6章函数.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
3. 执行过程: 设输入n?5 main ( ) { ? f=5?fac(4); ? } fac(4) { ? f=4?fac(3); ? return f; } fac(3) { ? f=3?fac(2); ? return f; } ? – fac=4! n=4 n=3 fac=3! fac(2) { ? f=2?fac(1); ? return f; } fac(1) { ? f=f (1); ? return f; } n=1 fac=1 n=2 fac=2! 可简化表示为 n=1 n=2 n=3 n=4 fac=4! fac=3! fac=2! fac=1 n=5 当变成机器代码时,将其拉成直线(线性程序代码)。 例6.11: P161汉诺塔(Hanoi)问题 B C A n个盘子 保证小(上),大(下) 问题: 将A塔上n个盘子移至C(借助于B)。 移动时,保证三个塔始终是大盘在下,小盘在上。 必须用递归方式解决 先将A塔n –1个盘子借助于C移至B上 2) 将A上剩下的一个移至C上. 3) 将B上n –1个盘子借助于A移至C上. 可以看到: 1)、3)为同一问题,都为n –1个盘子借助于一个空塔移至另一塔上。 程序如下: void move (getone, putone) char getone, putone; { printf( %c– –%c\n , getone, putone); } void hanoi (n, one, two, three) /*将n个盘从one借助two,移动three*/ char one, two, three; int n; { if (n= =1) move (one, three); else { hanoi (n–1, one, three, two); move (one, three); hanoi (n–1, two, one, three); } } main ( ) { int m; printf ( input the number of disdes :); scanf( %d ,m); printf( The step to moving %3d disdes:\n , m); hanoi (m, A, B, C); } 运行情况如下: input the number of disdes:3? The step to moving 3 diskes: A ? ?C A ? ?B C ? ?B A ? ?C B ? ?A B ? ?C A ? ?C 两个函数: ? move (getone, putone) 表示从getone 塔移一个盘子至putone塔 ? hanoi(n, one, two, three) 表示n个盘子从one塔借助于two塔(空)移至three塔。 调用时塔用字符常量A , B , C 表示。 让我们看一看, 当盘数是 3 时, towers() 的执行情况。 §6.5 变量作用域与存储方式 6.5.1 变量的作用域 变量有效的范围称变量的作用域。 C语言中所有的变量都有自己的作用域。变量说明的方式不同,其作用域也不同。C语言中的变量,按作用域范围可分为两种,即局部变量和全局变量。 一、局部变量 凡在函数(含main 函数)内部定义的变量称为局部变量。 局部性: 局部变量仅在函数内部有效。 其作用域仅限于函数内,在函数内才能引用,即可以对它赋值或取值。在作用域以外,使用它们是非法的。 2. 形参为局部变量。 3. 在复合语句中可定义仅复合语句中有效的临时变量。 1. 不同的函数可具有同名的变量,它们占不同的内存单元,互不影响。 二、全局变量 例: int p=1, q=5;

文档评论(0)

精品课件 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档