递归与回溯算法精选文档.ppt
《递归与回溯算法精选文档.ppt》由会员分享,可在线阅读,更多相关《递归与回溯算法精选文档.ppt(52页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、递归与回溯算法1 1本讲稿第一页,共五十二页递归的定义递归的定义 所谓递归就是一个函数或过程可以直接或间接地调用自己。我们大家所谓递归就是一个函数或过程可以直接或间接地调用自己。我们大家都熟悉一个民间故事:从前有一座山,山上有一座庙,庙里有一个老都熟悉一个民间故事:从前有一座山,山上有一座庙,庙里有一个老和尚正在给小和尚讲故事,故事里说,从前有一座山,山上有一座庙,和尚正在给小和尚讲故事,故事里说,从前有一座山,山上有一座庙,庙里有一个老和尚正在给小和尚讲故事,故事里的故事是说庙里有一个老和尚正在给小和尚讲故事,故事里的故事是说。象。象这种形式,我们就可以称之为递归的一种形象描述,老和尚什么时
2、候这种形式,我们就可以称之为递归的一种形象描述,老和尚什么时候不向下讲了,故事才会往回返,最终才会结束。不向下讲了,故事才会往回返,最终才会结束。再如:前面多次提到的求再如:前面多次提到的求N!的问题。的问题。我们知道:当我们知道:当N0时,时,N!=N*(N-1)!,因此,求,因此,求N!的问题化成了求的问题化成了求N*(N-1)!的问题,而求的问题,而求(N-1)!的问题又与求的问题又与求N!的解法相同,只不过是求阶乘的的解法相同,只不过是求阶乘的对象的值减去了对象的值减去了1,当,当N的值递减到的值递减到0时,时,N!=1,从而结束以上过程,求,从而结束以上过程,求得了得了N!的解。的解
3、。2 2本讲稿第二页,共五十二页也就是说,求解也就是说,求解N!的过程可以用以下递归方法来表示:的过程可以用以下递归方法来表示:在这里,为了定义在这里,为了定义n!,就必须先定义,就必须先定义(n-1)!,为了定义,为了定义(n-1)!,又必须先定义,又必须先定义(n-2)!,上述这种用自身的简单情况来定,上述这种用自身的简单情况来定义自己的方式称为递归定义。义自己的方式称为递归定义。一个递归定义必须是有确切含义的,也就是说,必须一步比一一个递归定义必须是有确切含义的,也就是说,必须一步比一步简单,最后是有终结的,决不允许无限循环下去。步简单,最后是有终结的,决不允许无限循环下去。上面的例子中
4、,当上面的例子中,当N=0时定义一个数时定义一个数1,是最简单的情况,是最简单的情况,称为递归的边界,它本身不再使用递归定义。称为递归的边界,它本身不再使用递归定义。与递推一样,每一递归都有其边界条件。但不同的是,递推是由边与递推一样,每一递归都有其边界条件。但不同的是,递推是由边界条件出发,通过递推式来求值,而递归则是从自身出发来达到边界界条件出发,通过递推式来求值,而递归则是从自身出发来达到边界条件。条件。3 3本讲稿第三页,共五十二页递归的调用递归的调用 在在Pascal程序中,子程序可以直接自己调用自己或间接调用自程序中,子程序可以直接自己调用自己或间接调用自己,则将这种调用形式称之为
5、递归调用。己,则将这种调用形式称之为递归调用。其中,我们将前者的调用方式称为简单递归,后者称为间接递归。其中,我们将前者的调用方式称为简单递归,后者称为间接递归。由于目前我们介绍、掌握的知识尚还无法实现间接递归,只有留待由于目前我们介绍、掌握的知识尚还无法实现间接递归,只有留待在以后的内容中我们再作介绍。本节只介绍直接递归。在以后的内容中我们再作介绍。本节只介绍直接递归。递归调用时必须符合以下三个条件:递归调用时必须符合以下三个条件:(1)可将一个问题转化为一个新的问题,而新问题的解决方法仍)可将一个问题转化为一个新的问题,而新问题的解决方法仍与原问题的解法相同,只不过所处理的对象有所不同而已
6、,即它们只与原问题的解法相同,只不过所处理的对象有所不同而已,即它们只是有规律的递增或递减。是有规律的递增或递减。(2)可以通过转化过程使问题回到对原问题的求解。)可以通过转化过程使问题回到对原问题的求解。(3)必须要有一个明确的结束递归的条件,否则递归会无止)必须要有一个明确的结束递归的条件,否则递归会无止境地进行下去。境地进行下去。下面我们通过一些例子,来解释递归程序的设计。下面我们通过一些例子,来解释递归程序的设计。4 4本讲稿第四页,共五十二页programaa;vart:longint;n:integer;functionfac(n:integer):longint;beginifn
7、=0thenfac:=1elsefac:=fac(n-1)*n;end;例例1:按照以上的分析,用递归的方法来求:按照以上的分析,用递归的方法来求N!的解。!的解。程序如下:程序如下:测试数据:测试数据:输入:输入:inputn=5输出:输出:5!=120beginwrite(inputn=);read(n);ifn0thenwriteln(n0,dataerrer)elsebegint:=fac(n);writeln(n,!=,t)endend.5 5本讲稿第五页,共五十二页如图展示了程序的执行过程:如图展示了程序的执行过程:在在这这里,因里,因为为函数函数FAC的形参的形参是是值值形参,因
8、此每形参,因此每调调用一次用一次该该函函数,系数,系统统就就为为本次本次调调用的用的值值形参形参N开辟了一个存开辟了一个存储单储单元,以便存放元,以便存放它的它的实实参的参的值值。也就是。也就是说说,对对于于递归递归函数或函数或递归过递归过程,每当程,每当对对它它调调用一次用一次时时,系,系统统都要都要为为它的形它的形式参数与局部式参数与局部变变量(在函数或量(在函数或过过程中程中说说明的明的变变量)分配存量)分配存储单储单元元(这这是一个独立的是一个独立的单单元,元,虽虽然名然名字相同,但字相同,但实际实际上是互不相干的,上是互不相干的,只在本只在本层层内有效),并内有效),并记记下返回下返
9、回的地点,以便返回后程序从此的地点,以便返回后程序从此处处开始开始执执行。行。6 6本讲稿第六页,共五十二页例例2:读入一串字符倒序输出,以字符:读入一串字符倒序输出,以字符&为结束标志,用过程来实现。为结束标志,用过程来实现。分析:由题意可知,读一串字符当然只能一个个地读入,要倒序输出,分析:由题意可知,读一串字符当然只能一个个地读入,要倒序输出,就要一直读到字符就要一直读到字符&。如输入的一段字符为。如输入的一段字符为ABCDEFGH&,则倒,则倒序输出的结果应该是序输出的结果应该是&HGFEDCBA。(1)读入一个字符;)读入一个字符;(2)读(该字符后的)子串并倒序输出;)读(该字符后
10、的)子串并倒序输出;(3)然后输出读入字符(指()然后输出读入字符(指(1)读入的字符)读入的字符)(4)在()在(2)中若子串是空(即遇字符)中若子串是空(即遇字符&),表示子串已完,),表示子串已完,不再处理子串。不再处理子串。以上(以上(2)表示一操作依赖另一操作,所以需要用递归调用。)表示一操作依赖另一操作,所以需要用递归调用。(4)表示已知操作(递归的终止)。)表示已知操作(递归的终止)。7 7本讲稿第七页,共五十二页程序如下:程序如下:programaa;procedurereverse;varch:char;beginread(ch);ifch&thenreverse;write
11、(ch);end;beginreverse;writeln;end.测试数据:测试数据:输入:输入:abcdefghijklmn&输出:输出:&nmlkjihgfedcba8 8本讲稿第八页,共五十二页例例3:利用递归,将一个十进制整数:利用递归,将一个十进制整数K转化为转化为N进制整数(进制整数(N=10)。)。测试数据:测试数据:输入:输入:K和和N的值的值193输出:转化后的输出:转化后的N进制整数进制整数201programaa;varn,k:integer;proceduretentok(k,n:integer);varr:integer;beginr:=kmodn;k:=kdivn
12、;ifk0thententok(k,n);write(r);end;beginread(k,n);tentok(k,n);writeln;end.9 9本讲稿第九页,共五十二页递归的一般适合场合1数据的定义形式是按递归定义的数据的定义形式是按递归定义的.如:裴波那契数列的定义为:如:裴波那契数列的定义为:Fn=Fn-1+Fn-2F1=0F2=1beginread(n);s:=fib(n);writeln(s);end.测试数据:测试数据:输入:输入:5输出:输出:3programaa;varn:integer;s:longint;FunctionFIB(N:integer):integer;B
13、eginIfn=1thenFIB:=0Elseifn=2thenFIB:=1ElseFIB:=FIB(n-1)+FIB(n-2)End;1010本讲稿第十页,共五十二页例如;著名的例如;著名的Hanoi塔(汉诺塔)问题。塔(汉诺塔)问题。3数据之间的结构关系按递归定义的数据之间的结构关系按递归定义的例如:大家将在后面的学习内容中遇到的树的遍例如:大家将在后面的学习内容中遇到的树的遍历、图的搜索等问题。历、图的搜索等问题。2问题的求解方法是按递归算法来实现的。问题的求解方法是按递归算法来实现的。1111本讲稿第十一页,共五十二页判断运行结果1.programd1;vars,n:integer;f
14、unctionf(n:integer):integer;beginifn=1thenf:=1elsef:=n*n+f(n-1);end;beginwrite(inputn:);readln(n);s:=f(n);writeln(f(,n,)=,s)end.输入输入:inputn:3输出输出:练习一1212本讲稿第十二页,共五十二页2programd2;vara,b:integer;functionf(n:integer):integer;beginifn=1thenf:=1elseifn=2thenf:=2elsef:=f(n-1)+f(n-2);end;beginread(a);b:=f(a
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 递归 回溯 算法 精选 文档
限制150内