第7章函数调用(2).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文档。上传文档
查看更多
练 习1 从键盘上输入两个任意整数a,b(ab),求a,b之间所有整数的和(包括a,b)。 分析:可以将求a,b之间所有整数的和定义为一个函数,将该函数命名为sum(a,b)。 主程序只要输入a,b,调用该函数即可。 练 习2 从键盘上输入两个任意整数a,b(ab),求a,b两个数之间的最大值(包括a,b)。 分析:可以将求a,b之间求最大值定义为一个函数,将该函数命名为max(a,b)。 主程序只要输入a,b,调用该函数即可。 如果求3个数或者4个数之间的最大值?怎么求? 原来的函数怎么修改? 例7.9 输入10个数,要求输出其中值最大的元素和该数是第几个数。 解题思路: 定义数组a,用来存放10个数 设计函数max,用来求两个数中的大者 在主函数中定义变量m,初值为a[0],每次调用max函数后的返回值存放在m中 用“打擂台”算法,依次将数组元素a[1]到a[9]与m比较,最后得到的m值就是10个数中的最大者 例7.11 有两个班级,分别有35名和30名学生,调用一个average函数,分别求这两个班的学生的平均成绩。 练习  P219.(14) 求和 //#include stdio.h //int sum(int x,int y) //{ // int z;[求和] // z=x+y; // return z; //} //void main(void) //{int a,b,c; // scanf(%d%d,a,b); // c=sum(a,b); // printf(The sum is%d\n,c); //} 求最大值 //#includestdio.h //int max(int x,int y)[求最大值] //{ int z; //z=(xy?x:y); // return z; //} // void main(void) //{ int a,b,c; // scanf(%d%d,a,b); // c=max(a,b); // printf(The max is %d\n,c); 求四个数的最大值(嵌套) //#includestdio.h //int max(int x,int y)//[求四个数的最大值][函数的嵌套] //{ return (xy?x:y); } // int max_4(int a, int b,int c,int d) // { // int m; // m=max(a,b); // m=max(m,c); // m=max(m,d); // return m; // } //void main(void) // { int a,b,c,d,m; // scanf(%d%d%d%d,a,b,c,d); // m=max_4(a,b,c,d); // printf(The max is %d\n,m); // } long fac(int n) { int i; long fact=1; for(i=1;i=n;i++) fact=fact*i; return fact; } 2.用递归方法求n! 解题思路: 递归的思路和递推是相反的,并不是先求1 再 求1 × 2再× 3…,直到× n,而是直接从目标出发提出问题: 5!等于4!×5,而4!=3!×4…,而1!是已知的,不必再回溯了 #include stdio.h void main() { long fac(int n); int n,y; printf(input an integer number:); scanf(%d,n); y=fac(n); printf(%d!=%ld\n,n,y); } long fac(int n) { long f; if(n0) printf(“n0,data error!”); else if(n==0 || n==1) f=1; else f=fac(n-1)*n; return(f); } 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 递归调用的特点: 执行“未知→未知→…

文档评论(0)

xina171127 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档