循环与递归.ppt
《循环与递归.ppt》由会员分享,可在线阅读,更多相关《循环与递归.ppt(55页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、关于循环与递归关于循环与递归现在学习的是第1页,共55页第三章第三章 算法基本工具和优化技巧算法基本工具和优化技巧 n利用算法的利用算法的基本机制基本机制循环和递归设计循环和递归设计算法算法n利用算法的利用算法的基本操作基本操作提高算法效率的技巧提高算法效率的技巧n利用数组提高算法质量利用数组提高算法质量n建立高效的数学模型建立高效的数学模型本章主要讲解如何充分利用这些基本的程序设计技本章主要讲解如何充分利用这些基本的程序设计技术设计高质量的算法,在程序设计与算法设计之间起承术设计高质量的算法,在程序设计与算法设计之间起承上启下的作用上启下的作用现在学习的是第2页,共55页3.1.1循环设计要
2、点循环设计要点3.1.2 递归设计要点递归设计要点3.1.3递归与循环的比较递归与循环的比较3.1 循环与循环与递归递归现在学习的是第3页,共55页311 循环设计要点循环设计要点 1 1设计设计中要注意算法的效率中要注意算法的效率 2 2“自自顶顶向下向下”的的设计设计方法方法 3 3由具体到抽象设计循环结构由具体到抽象设计循环结构 现在学习的是第4页,共55页 循环体的特点是:循环体的特点是:“以不变应万变以不变应万变”。所谓所谓“不变不变”是指循环体内运算的表现形式是不变是指循环体内运算的表现形式是不变的的,如变量,控制结构如变量,控制结构,而每次具体的执行内容,而每次具体的执行内容数据
3、数据却是却是不尽相同的。在循环体内用不变的运算表现形式去描述不尽相同的。在循环体内用不变的运算表现形式去描述各种相似的重复运算。各种相似的重复运算。1 1循环循环设计设计中要注意算法的效率中要注意算法的效率现在学习的是第5页,共55页【例1】求1/1!-1/3!+1/5!-1/7!+(-1)n+1/(2n-1)!n分析:此问题中既有分析:此问题中既有累加累加又有又有累乘累乘,准确地说,准确地说累加的对象是累乘的结果。累加的对象是累乘的结果。数学模型数学模型1 1:Sn=Sn-1+Sn=Sn-1+(-1-1)n+1n+1/(2n-1)!/(2n-1)!算法设计算法设计1 1:多数初学者会直接利用
4、题目中累:多数初学者会直接利用题目中累加项通式,构造出循环体不变式为:加项通式,构造出循环体不变式为:S=S+S=S+(-1-1)n+1n+1/(2n-1)!/(2n-1)!需要用二重循环来完成算法,算法需要用二重循环来完成算法,算法1 1如下:如下:现在学习的是第6页,共55页算法如下:求(求(-1-1)n+1 for(j=1;j=i+1;j=j+1)for(j=1;j=i+1;j=j+1)sign=sign*(-1);sign=sign*(-1);s=s+sign/t;s=s+sign/t;print(“Snm=”,s);print(“Snm=”,s);main()main()int i,
5、n,j,sign=1;int i,n,j,sign=1;float s,t=1;float s,t=1;input(n);input(n);s=1s=1;for(i=2;i=n;i=i+1)for(i=2;i=n;i=i+1)t=1;t=1;求阶乘求阶乘 for(j=1;j=2*i-1;j=j+1)for(j=1;j=2*i-1;j=j+1)t=t*j;t=t*j;sign=1;sign=1;现在学习的是第7页,共55页算法分析:n以上算法是二重循环来完成以上算法是二重循环来完成,但算法的效率却太低是,但算法的效率却太低是O(n2)。)。当当前前一一次次循循环环已已求求出出7!,当当这这次次要
6、要想想求求9!时时,没没必必要要再再从从1去去累累乘乘到到9,只只需需要要充充分分利利用用前前一一次次的的结结果果,用用7!*8*9即即可可得得到到9!,模模型型为为An=An-1*1/(2*n-2)*(2*n-1)。另另外外运运算算sign=sign*(-1);总总共共也也要要进进行行n*(n-1)/2次次乘乘法法,这也是没有必要的。下面我们就进行改进。这也是没有必要的。下面我们就进行改进。现在学习的是第8页,共55页数学模型2:Sn=Sn-1+(-1)n+1An;An=An-1*1/(2*n-2)*(2*n-1)main()main()int i,n,sign;int i,n,sign;f
7、loat s,t=1;float s,t=1;input(n);input(n);s=1s=1;sign=1;sign=1;for(i=2;i=n;i=i+1)for(i=2;i=n;i=i+1)或或 for(i=1;i=n-1;i=i+1)for(i=1;i=n-1;i=i+1)sign=-sign;sign=-sign;t=t*(2*i-2)*(2*i-1);t=t*2*i*(2*i+1);t=t*(2*i-2)*(2*i-1);t=t*2*i*(2*i+1);s=s+sign/t;s=s+sign/t;s=s+sign/t;s=s+sign/t;print(“Sum=”,s);print
8、(“Sum=”,s);现在学习的是第9页,共55页算法分析:按照数学模型2,只需一重循环就能解决问题算法的时间复杂性为O(n)。算法说明算法说明2 2现在学习的是第10页,共55页2“自顶向下”的设计方法 自自顶顶向向下下的的方方法法是是从从全全局局走走向向局局部部、从从概概略略走走向向详详尽尽的的设设计计方方法法。自自上上而而下下是是系系统统分分解解和和细细化的化的过过程。程。【例例2 2】编算法找出编算法找出10001000以内所有完数以内所有完数例例如如,2828的的因因子子为为1 1、2 2、4 4、7 7,1414,而而28=1+2+4+7+1428=1+2+4+7+14。因因此此2
9、828是是“完完数数”。编编算算法法找找出出10001000之之内内的的所所有有完完数数,并并按按下下面面格格式式输出其因子:输出其因子:28 its factors are 128 its factors are 1,2 2,4 4,7 7,1414。现在学习的是第11页,共55页1 1)这这里里不不是是要要质质因因数数,所所以以找找到到因因数数后后也也无无需需将将其其从从数数据据中中“除掉除掉”。2 2)每每个个因因数数只只记记一一次次,如如8 8的的因因数数为为1 1,2 2,4 4而而不不是是1 1,2 2,2 2,2 2(注:本题限定因数不包括这个数本身)(注:本题限定因数不包括这个
10、数本身)现在学习的是第12页,共55页1 1)顶层算法)顶层算法for(i=2;i=n;i=i+1)i=2;i=n;i=i+1)判断判断i i是否是是否是“完数完数”;是是“完数完数”则按格式输出则按格式输出;2 2)判断)判断i i是否是是否是“完数完数”的算法的算法 for(j=2;ji;j=j+1)for(j=2;ji;j=j+1)找找i i的的因因子子,并并累累加加,如如果果累累加加值值等等于于i,i i,i 是是“完数完数”现在学习的是第13页,共55页3 3)进一步细化)进一步细化判断判断i i是否是否“完数完数”算法算法s=1for(j=2;ji;j=j+1)j=2;ji;j=j
11、+1)if(i mod j=0)(j if(i mod j=0)(j是是i i的因素的因素)s=s+j;)s=s+j;if if (s=is=i)i i是是“完数完数”;现在学习的是第14页,共55页 定义数组定义数组a,s=1;k=0;for(j=2;ji;j=j+1)j=2;ji;j=j+1)if(i mod j=0)(j if(i mod j=0)(j是是i i的因素的因素)s=s+j;ak=j;k=k+1;s=s+j;ak=j;k=k+1;if if (s=is=i)按格式输出结果按格式输出结果 4)考虑输出格式判断i是否“完数”算法n考虑到要按格式输出结果,应该开辟数组存储考虑到要按
12、格式输出结果,应该开辟数组存储数据数据i的所有因子,并记录其因子的个数,因的所有因子,并记录其因子的个数,因此算法细化如下:此算法细化如下:现在学习的是第15页,共55页算法如下:算法如下:main()inti,k,j,s,a20;for(i=1;i=1000;i+)s=1;/*两个赋初值语句两个赋初值语句s=1,k=0k=0;一定要位于外部循环的内部一定要位于外部循环的内部*/for(j=2;ji;j+)if(imodj)=0)s=s+j;ak=j;k+;if(i=s)print(s,“itsfactorsare:”,1);for(j=0;ik;j+)print(“,”,ak);现在学习的是
13、第16页,共55页【例3】求一个矩阵的鞍点 (即在行上最小而在列上最大的点)。算法设计:算法设计:1)在第一行找最小值,并记录其列号。)在第一行找最小值,并记录其列号。2)然后验证其是否为所在列的最大值,如果是,则找到问题)然后验证其是否为所在列的最大值,如果是,则找到问题的解;否则,则继续在下一行找最小值的解;否则,则继续在下一行找最小值 。现在学习的是第17页,共55页for(i=0;in;i=i+1)i=0;in;i=i+1)找第找第i i行上最小的元素行上最小的元素t t及所在列及所在列minj;minj;检验检验t t是否第是否第minj minj 列的最大值,是则输出鞍点列的最大值
14、,是则输出鞍点;t=ai0;minj=1;t=ai0;minj=1;for(j=1;jn;j=j+1)for(j=1;jn;j=j+1)if(aijt)if(aijt)t=aij;t=aij;minj=j;minj=j;1 1)顶层算法)顶层算法 2 2)找第)找第i i行上最小的元素行上最小的元素t t及所在列及所在列minj minj 现在学习的是第18页,共55页3 3)检验)检验t t是否第是否第minjminj列的最大值,是,则输出鞍点列的最大值,是,则输出鞍点;for(k=0;kn;k=k+1)for(k=0;kt)break;if(akminjt)break;if(kn)cont
15、inue;if(kn)continue;print(“the print(“the result result is is a“,i a“,i,“”,minj,minj,“=”“=”,t);t);考考虑虑到到会会有有无无解解的的情情况况,设设置置标标志志量量kzkz,kz=0kz=0代代表表无无解解,找找到到一一个个解解后,后,kzkz被赋值为被赋值为1 1,就不再继续找鞍点的工作。,就不再继续找鞍点的工作。请请考考虑虑是是否否有有多多解解的的可可能能性性吗吗?若若有有,请请改改写写算算法法,找找出出矩矩阵阵中中所所有有的的鞍鞍点。点。现在学习的是第19页,共55页算法如下:算法如下:buck
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 循环 递归
限制150内