第2章 递归与分治策略ppt课件.ppt

第2章 递归与分治策略ppt课件.ppt

ID:58935059

大小:661.00 KB

页数:86页

时间:2020-09-28

第2章 递归与分治策略ppt课件.ppt_第1页
第2章 递归与分治策略ppt课件.ppt_第2页
第2章 递归与分治策略ppt课件.ppt_第3页
第2章 递归与分治策略ppt课件.ppt_第4页
第2章 递归与分治策略ppt课件.ppt_第5页
资源描述:

《第2章 递归与分治策略ppt课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、计算机算法设计与分析DesignandAnalysisofComputerAlgorithms第二章递归与分治策略7/29/20211理解递归的概念。掌握设计有效算法的分治策略。通过下面的范例学习分治策略设计技巧。(1)二分搜索技术;(2)大整数乘法;(3)Strassen矩阵乘法;(4)棋盘覆盖;(5)合并排序和快速排序;(6)线性时间选择;(7)最接近点对问题;(8)循环赛日程表。学习要点:7/29/20212将要求解的较大规模的问题分割成k个更小规模的子问题。算法总体思想nT(n/2)T(n/2)T(n/

2、2)T(n/2)T(n)=对这k个子问题分别求解。如果子问题的规模仍然不够小,则再划分为k个子问题,如此递归的进行下去,直到问题规模足够小,很容易求出其解为止。7/29/20213算法总体思想将求出的小规模的问题的解合并为一个更大规模的问题的解,自底向上逐步求出原来问题的解。nT(n)=n/2T(n/4)T(n/4)T(n/4)T(n/4)n/2T(n/4)T(n/4)T(n/4)T(n/4)n/2T(n/4)T(n/4)T(n/4)T(n/4)n/2T(n/4)T(n/4)T(n/4)T(n/4)7/29/2

3、0214分治法的设计思想是,将一个难以直接解决的大问题,分割成一些规模较小的相同问题,以便各个击破,分而治之。凡治众如治寡,分数是也。----孙子兵法7/29/20215提纲一、递归的概念二、分治法的基本思想三、分治法的应用7/29/20216提纲一、递归的概念二、分治法的基本思想三、分治法的应用7/29/20217递归的概念直接或间接地调用自身的算法称为递归算法。用函数自身给出定义的函数称为递归函数。由分治法产生的子问题往往是原问题的较小模式,这就为使用递归技术提供了方便。在这种情况下,反复应用分治手段,可以

4、使子问题与原问题类型一致而其规模却不断缩小,最终使子问题缩小到很容易直接求出其解。这自然导致递归过程的产生。分治与递归像一对孪生兄弟,经常同时应用在算法设计之中,并由此产生许多高效算法。下面来看几个实例。7/29/20218一、递归的概念例1阶乘函数边界条件递归方程intfactorial(intn){if(n==0)return1;returnn*factorial(n-1);}边界条件与递归方程是递归函数的二个要素。递归函数只有具备了这两个要素,才能在有限次计算后得出结果。7/29/20219一、递归的概念

5、例2Fibonacci数列无穷数列1,1,2,3,5,8,13,21,34,55,……,称为Fibonacci数列。递归定义为:intfibonacci(intn){if(n<=1)return1;returnfibonacci(n-1)+fibonacci(n-2);}边界条件递归方程7/29/202110一、递归的概念例3Ackerman函数前2例中的函数都可以找到相应的非递归方式定义:本例中的Ackerman函数却无法找到非递归的定义。7/29/202111一、递归的概念例3Ackerman函数当一个函数

6、及它的一个变量是由函数自身定义时,称这个函数是双递归函数。Ackerman函数A(n,m)定义如下:7/29/202112一、递归的概念例4排列问题设计一个递归算法生成n个元素{r1,r2,…,rn}的全排列。设R={r1,r2,…,rn}是要进行排列的n个元素,Ri=R-{ri}。集合X中元素的全排列记为perm(X)。(ri)perm(X)表示在全排列perm(X)的每一个排列前加上前缀ri得到的排列。R的全排列可归纳定义如下:当n=1时,perm(R)=(r),其中r是集合R中唯一的元素;当n>1时,pe

7、rm(R)由(r1)perm(R1),(r2)perm(R2),…,(rn)perm(Rn)构成。7/29/202113templatevoidperm(Tlist[],intk,intm){//产生list[k:m]的所有排列if(k==m){//单元素排列for(inti=0;i<=m;i++)cout<

8、1,m);swap(list[k],list[i]);}}思想:当首项和最后一项相等,说明排列结束就需要输出了当首项和最后一项不同,首先利用循环把首项和循环中的每一项对调作为首字符(或数字),之后进行从后一位开始的全排列。再循环中需要把交换过去的,再换回来一边下一次进行循环时候使用。7/29/202114一、递归的概念例5整数划分问题将正整数n表示成一系列正整数之和:n=n1+n2+…

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。