- 1、本文档共38页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第一章算法与程序设计概述-Read.ppt
Visual FoxPro 3.1 递归及其应用 3.2 分治法概述 3.3 分治法的基本应用 3.4 消除递归 3.1 递归及其应用 3.1.1 递归与递归调用 一个函数在它的函数体内调用它自身称为递归(recursion) 调用。 使用递归要注意以下几点: (1) 递归就是在过程或函数里调用自身; (2) 在使用递增归策略时,必须有一个明确的递归结束条件,称为递归出口递归和分治是相统一的,递归算法中含有分治思想,分治算法中也常用递归算法。 例如有函数r如下: int r (int a) { b=r(a-1); return b; } 这个函数是一个递归函数。但是运行该函数将无休止地调用其自身,这显然是不正确的。为了防止递归调用无终止地进行,必须在函数内有终止递归调用的手段。常用的办法是加条件判断,满足某种条件后就不再作递归调用,然后逐层返回。 3.1.2 递归应用 【例3.1】 用递归法计算n!。 [分析] n!的计算是一个典型的递归问题。使用递归方法来描述程序,十分简单且易于理解。 [步骤1] 描述递归关系 递归关系是这样的一种关系。设{U1,U2,U3,…,Un…}是一个序列,如果从某一项k开始,Un和它之前的若干项之间存在一种只与n有关的关系,这便称为递归关系。 注意到,当n=1时,n!=n*(n-1)!(n=0时,0!=1),这就是一种递归关系。对于特定的k!,它只与k与(k-1)!有关。 [步骤2] 确定递归边界 在步骤1的递归关系中,对大于k的Un的求解将最终归结为对Uk的求解。这里的Uk称为递归边界(或递归出口)。在本例中,递归边界为k=0,即0!=1。对于任意给定的N!,程序将最终求解到0!。 确定递归边界十分重要,如果没有确定递归边界,将导致程序无限递归而引起死循环。例如以下程序: #include stdio.h int f(int x){ return(f(x-1)); } main(){ printf(f(5)); } 它没有规定递归边界,运行时将无限循环,会导致错误。 [步骤3] 写出递归函数并译为代码 将步骤1和步骤2中的递归关系与边界统一起来用数学语言来表示,即 n*(n-1)! 当n=1时 n!= 1 当n=0时 再将这种关系翻译为代码,即一个函数: long ff(int n){ long f; if(n0) printf(n0,input error); else if(n==0||n==1) f=1; else f=ff(n-1)*n; return(f); } [步骤4] 完善程序 主要的递归函数已经完成,将程序依题意补充完整即可。 #include stdio.h long ff(int n){ long f; if(n0) printf(n0,input error); else if(n==0||n==1) f=1; else f=ff(n-1)*n; return(f); } void main() { int n; long y; printf(\n input a integer number:\n); scanf(%d,n); y=ff(n); printf(%d!=%ld,n,y); } 3.2 分治法概述 3.2.1 分治法基本思想 在算法设计中,首先对求解问题进行系统的分析,之后将其分解成若干性质相同的子问题,所得结果称为求解子集,再对这些求解子集分别处理。如果某些子集还需分而治之,再递归的使用上述方法,直到求解子集不需要再细分为止。最后归并子集的解即得原问题的解。 因而对分治法算法设计过程可以如下描述: 设原问题输入为a[n],简记为(1,n); 子问题为a[p]a[q],1≤p≤q≤n,简记为(p,q)。 已知: SOLUTION; int divide (int, int); int small (int, int); SOLUTION conquer (int, int); SOLUTION combine (SOLUTION, SOLUTION); 分治法的抽象控制算法为: SOLUTION DandC(p,q) /* divide and conquer */ { if(small(p,q)) return conquer(p,q); else { m=divide(p,q); return combine( DandC(p,m), DandC(m+1,q) );
您可能关注的文档
- 第15章禽类的解剖生理特征.ppt.ppt
- 第1章数据结构.ppt.ppt
- 第1章自我评量-2.doc
- 第2章光电检测器件工作原理及特性2.1光电检测器件的物理基础一.ppt
- 第2章岩石的成因类型及其工程地质特征-南京工程高等职业学校.ppt
- 第3章供应链管理中的信息技术第三章供应链管理中的信息技术.ppt
- 第3章分形模型和系统.doc
- 第3章语法分析-Read.ppt
- 第3节第1课时实数课前预习要点感知1无限小数叫做无理数,和统称.doc
- 第3课操作符和编程结构.ppt
- 浙江衢州市卫生健康委员会衢州市直公立医院高层次紧缺人才招聘11人笔试模拟试题参考答案详解.docx
- 浙江温州泰顺县退役军人事务局招聘编外工作人员笔试备考题库及参考答案详解一套.docx
- 江苏靖江市数据局公开招聘编外工作人员笔试模拟试题及参考答案详解.docx
- 广东茂名市公安局电白分局招聘警务辅助人员40人笔试模拟试题带答案详解.docx
- 江苏盐城市大丰区住房和城乡建设局招聘劳务派遣工作人员4人笔试模拟试题带答案详解.docx
- 浙江舟山岱山县东沙镇人民政府招聘笔试模拟试题及参考答案详解1套.docx
- 最高人民检察院直属事业单位2025年度公开招聘工作人员笔试模拟试题含答案详解.docx
- 浙江金华市委宣传部、中共金华市委网信办所属事业单位选调工作人员笔试备考题库及答案详解1套.docx
- 广东深圳市党建组织员招聘40人笔试模拟试题及答案详解1套.docx
- 江苏南京水利科学研究院招聘非在编工作人员4人笔试模拟试题及参考答案详解.docx
最近下载
- SY 4201.4-2016 石油天然气建设工程施工质量验收规范 设备安装工程 第4部分:炉类.docx VIP
- 电力市场分析软件:PLEXOS二次开发_(13).电力市场改革与趋势分析.docx VIP
- 云和雪梨生产全程质量控制技术规范.docx VIP
- 电力市场分析软件:PLEXOS二次开发_(12).可视化与报告生成.docx VIP
- 2024-2025学年四川省成都市新都一中实验学校七年级(上)分班数学模拟试卷(含答案).pdf VIP
- 跨座式与悬挂式单轨运输系统幻灯片.ppt VIP
- 市场营销论文:长春农商银行小微企业贷款业务市场营销策略研究.docx VIP
- 电力市场分析软件:PLEXOS二次开发_(11).数据库管理与接口设计.docx VIP
- 电力市场分析软件:PLEXOS二次开发_(10).二次开发工具与技巧.docx VIP
- 有机肥采购项目投标书(范本).docx
文档评论(0)