第三章第8讲(1693KB).pptVIP

  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文档。上传文档
查看更多
* * C语言规定:函数定义不可嵌套,但可以嵌套调用函数 函数的嵌套调用 嵌套调用:在调用一个函数的过程中又调用了另外一个函数 嵌套调用的执行过程:从什么地方调用函数,就返回到什么地方。 顺序调用 函数的顺序调用和嵌套调用 顺序调用 f1() { ……} f2() { ……} void main( ) { …… f1( ); …… f2( ); …… } * * main f1 f2 main f1 f2 函数的顺序调用和嵌套调用 嵌套调用 f1() { …… f2( ); ……} f2() { ……} void main( ) { …… f1( ); …… } * * main f1 f2 main f1 f2 * * 函数的嵌套调用举例—求Cnm long jch (int t) { int i ; long s=1; for(i=1;i=t;i++) s*=i; return ( s ) ; } long func( int x , int y) { long f ; f = jch(x) / ( jch(y) * jch(x-y) ); return ( f ) ; } main( ) { int m,n,z; scanf(%d%d,m,n); z=func(m,n); printf(%ld\n, z ); } 返回 func函数 在main 函数中调用func 函数 在func 函数中三次调用jch 函数 返回 main 函数 函数jch的功能是求形参t 的阶乘 main( ) 调用func()函数 结束 func()函数 jch函数 调用jch()函数 ? ? ? ? ? ? ? ? ? ——函数嵌套调用的示意图 * * 【例】计算三个整数中最大数与最小数的差。 #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); } int dif (int x, int y, int z) { return (max(x, y, z) – min(x, y, z)); } int max (int x, int y, int z) { int r; r = x y ? x : y; return (r z ? r : z); } int min (int x, int y, int z) { int r; r = x y ? x : y; return (r z ? r : z); } main( ) 调用函数dif 输出 结束 dif函数 max函数 调用函数max 调用函数min min函数 许多数学函数都是使用递归调用形式定义的: * * 函数的递归调用(递归函数) 当n=0,1时 当n1时 当n=0时 当n!=1时 函数的递归调用是指在调用一个函数时又直接或间接调用函数本身. * * 直接调用 间接调用 函数的递归调用(递归函数) 函数的递归调用(递归函数) 用递归实现的问题,满足两个条件: 问题可以逐步简化成自身较简单的形式(递归式) n! = n * (n-1)! n n-1 Σi = n +Σ i i=1 i=1 递归最终能结束(递归出口) 两个条件缺一不可 解决递归问题的两个着眼点 * * * * 例1 求n! long fact (int n) { long f = 1; int i; for (i = 1; i = n; i++) f *= i; return ( f ); } 方法一:利用循环 因为n! = n * (n-1) * (n-2) * … * 2 * 1,我们完全可以用循环语句来编写这个非递归函数fact: 方法二:利用递归 n! = 1 当n = 0,1时 n * (n - 1)! 当n 1时 long fact (int n

文档评论(0)

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

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

1亿VIP精品文档

相关文档