版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
ITEducation&TrainingNeusoftInstituteofInformationDate:10十月办公室:C7座201EMAIL:huang.w@课件下载网址:任课教师:黄伟第五章函数讲课关键点函数嵌套调用函数递归调用函数嵌套调用f1(){
…f2();
…}f2(){
…f3();
…}f3(){
…
…
…}函数嵌套调用举例1main(){inta=3,b=5,s;s=cal(a,b);printf(“%d”,s);}intcal(intx,inty){intresult,s1,s2;s1=powl(x,y);s2=pow(y,x);result=s1+s2;returnresult;}intpow(intm,intn){inti,res=1;for(i=0;i<n;i++)res*=m;returnres;}求3+5。53函数嵌套调用举例2自定义函数mymax2(),求出2个参数最大值,然后定义函数mymax3(),调用mymax2()求出3个参数中最大值,将值返回给主函数,输出该结果。函数首部为:floatmymax3(floatx,floaty,floatz)
模仿练习1、自定义函数mymax(),求出3个参数最大值;自定义函数mymin(),求出3个参数最小值;自定义函数mysub(),调用mymax()和mymin()求出3个参数最大值与最小值差;在主函数中调用mysub(),输出结果。 函数首部为:floatmymax(floatx,floaty,floatz) floatmymin(floatx,floaty,floatz)floatmysub(floatx,floaty,floatz)2、计算s=1k+2k+3k+……+Nk函数首部为:longf1(intn,intk) /*计算nk次方*/
longf2(intn,intk) /*计算1到nk次方之累加和*/
案例解答#defineK4#defineN5longf1(intn,intk) /*计算nk次方*/{longpower=n;inti;for(i=1;i<k;i++)power*=n;returnpower;}longf2(intn,intk) /*计算1到nk次方之累加和*/{longsum=0; inti;for(i=1;i<=n;i++)sum+=f1(i,k);returnsum;}main(){printf("Sumof%dpowersofintegersfrom1to%ld=",K,N);printf("%d\n",f2(N,K));}函数递归调用C语言函数调用允许直接或间接地调用该函数本身,称为函数递归调用。含有直接或间接调用自己函数称为递归函数。函数f调用函数f函数f1调用函数f2调用函数f1函数f2直接调用本身间接调用本身函数递归调用举例用递归函数求4!4!=4*3!;3!=3*2!;2!=2*1!;1!=1;n!=n*(n-1)!1!=1函数递归调用举例例:用递归函数求n!n!=n*(n-1)!intmyFac(intn){if(n==1)return1;//递归结束条件
returnn*myFac(n-1);}myFac(n)就是求n!myFac(n-1)就是求(n-1)!函数递归调用举例fac(3)*4fac(2)*3fac(1)*2reutrn(1)reutrn(1*2)reutrn(2*3)return(6*4)调用过程返回过程fac(4)reutrn(24)用递归函数求4!函数递归调用举例例:用递归函数求n!完整程序#include<stdio.h>intmyFac(intn);main(){ intf,n; scanf("%d",&n); f=myFac(n); printf("%d!=%d\n",n,f);}intmyFac(intn){ ints;if(n==1) s=1;//递归结束条件
elses=n*myFac(n-1);returns;}单步调试,了解递归程序执行流程函数递归调用举例递归算法组成:递归终止条件:当满足一定条件时,递归调用必须能够结束,不然会无限地递归调用而造成程序无法结束。比如n!中当n=1时,令结果为1则能够结束递归调用,不然它将继续调用(0)!而无限继续下去。对于由多个通项表示情况,则需要给出最终一个递归调用全部项值。如an=an-1+an-2,要给出n=1时结果以及n=2时结果才能够结束递归调用。递归表示式,如fac(n)=n*fac(n-1)函数递归调用举例求下数列第20项值。1,2,3,5,8,13,21,34……a1=1;a2=2;a3=a1+a2;…an=an-1+an-2;
函数递归调用举例求下数列第20项值。1,2,3,5,8,13,21,34……f(1)=1;f(2)=2;f(n)=f(n-1)+f(n-2);
函数递归调用举例main(){inta;a=f(20);printf(“%d”,a);}
intf(intn){ints;if(n==1)s=1;elsei
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 书记专题会听取巡察情况汇报制度
- 临床关怀科制度
- 机关单位离退休人员服务及管理制度
- 2026广东惠州市博罗县榕盛城市建设投资有限公司下属全资子公司招聘2人备考题库参考答案详解
- 2026新疆天润唐王城乳品有限公司招聘6人备考题库及完整答案详解1套
- 2026年度威海荣成市事业单位公开招聘初级综合类岗位人员备考题库(84人)及答案详解(新)
- 2026广东佛山市公共交通管理有限公司招聘1人备考题库及1套参考答案详解
- 2026中粮期货社会招聘备考题库附答案详解
- 2025广东惠州市龙川县事业单位集中招聘工作人员面试备考题库及1套完整答案详解
- 2026年1月广东湛江市坡头区人力资源和社会保障局招聘编外人员2人备考题库及1套完整答案详解
- 会销主持培训课件
- 2025新能源集控中心规范化管理导则
- 2025届新疆乌鲁木齐市高三下学期三模英语试题(解析版)
- 混动能量管理与电池热管理的协同优化-洞察阐释
- T-CPI 11029-2024 核桃壳滤料标准规范
- 统编版语文三年级下册整本书阅读《中国古代寓言》推进课公开课一等奖创新教学设计
- 2025年江苏省苏州市初三上学期物理期末阳光调研测试卷及答案
- 《顾客感知价值对绿色酒店消费意愿的影响实证研究-以三亚S酒店为例(附问卷)15000字(论文)》
- 学校教职工代表大会会议会务资料汇编
- 赵然尊:胸痛中心时钟统一、时间节点定义与时间管理
- 诊所护士聘用合同
评论
0/150
提交评论