网站大量收购独家精品文档,联系QQ:2885784924

算法第3章递归与分治.ppt

  1. 1、本文档共47页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
算法第3章递归与分治

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:Hanoi塔问题 [问题描述]在霍比特人的圣庙里,有一块黄铜板,上面插着3根宝石针(分别为A号,B号和C号)。在A号针上从下到上套着从大到小的n个圆形金片。现要将A针上的金片全部移到C针上,且仍按照原来的顺序叠置。移动的规则如下:这些金片只能在3根针间移动,一次只能一片,且任何时候都不允许将较大的金片压在较小的上面。从键盘输入n,要求给出移动的次数和方案。 规则1:每次只能移动1个圆盘; 规则2:任何时刻都将较大的圆盘放在较小的圆盘之上; 规则3:在满足移动规则1和2的前提下,可将圆盘移至a,b,c中任一塔座上。 由金片的个数建立递归关系。当n=1时,只要将唯一的金片从A移到C即可。当n1时,只要把较小的(n-1)片按移动规则从A移到B,再将剩下的最大的从A移到C(即中间“借助”B把金片从A移到C),再将B上的(n-1)个金片按照规则从B移到C(中间“借助”A)。 本题的特点在于不容易用数学语言写出具体的递归函数,但递归

文档评论(0)

xy88118 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档