第一章算法与程序设计概述-Read.ppt

  1. 1、本文档共38页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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) );

您可能关注的文档

文档评论(0)

170****0532 + 关注
实名认证
内容提供者

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

版权声明书
用户编号:8015033021000003

1亿VIP精品文档

相关文档