循环递归算法设计

循环递归算法设计

ID:43777043

大小:201.50 KB

页数:54页

时间:2019-10-14

循环递归算法设计_第1页
循环递归算法设计_第2页
循环递归算法设计_第3页
循环递归算法设计_第4页
循环递归算法设计_第5页
资源描述:

《循环递归算法设计》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、第三章算法设计第三章算法基本工具和优化技巧利用算法的基本机制——循环和递归设计算法利用算法的基本操作提高算法效率的技巧利用数组提高算法质量建立高效的数学模型3.1循环与递归3.3算法优化基本技巧3.2算法与数据结构3.4优化算法的数学模型3.1.1循环设计要点3.1.2递归设计要点3.1.3递归与循环的比较3.1循环与递归3.1.1循环设计要点1.设计中要注意算法的效率2.“自顶向下”的设计方法3.由具体到抽象设计循环结构循环体的特点是:“以不变应万变”。所谓“不变”是指循环体内运算的表现形式是不

2、变的,而每次具体的执行内容却是不尽相同的。在循环体内用不变的运算表现形式去描述各种相似的重复运算。1.循环设计中要注意算法的效率【例1】求1/1!-1/3!+1/5!-1/7!+…+(-1)n+1/(2n-1)!分析:此问题中既有累加又有累乘,准确地说累加的对象是累乘的结果。 数学模型1:Sn=Sn-1+(-1)n+1/(2n-1)!算法设计1:多数初学者会直接利用题目中累加项通式,构造出循环体不变式为:S=S+(-1)n+1/(2n-1)!需要用二重循环来完成算法,算法1如下:算法如下:求(-

3、1)n+1for(j=1;j<=i+1;j=j+1)sign=sign*(-1);s=s+sign/t;}print(“Snm=”,s);}main(){inti,n,j,sign=1;floats,t=1;input(n);s=1;for(i=2;i<=n;i=i+1){t=1;求阶乘for(j=1;j<=2*i-1;j=j+1)t=t*j;sign=1;算法分析:以上算法是二重循环来完成,但算法的效率却太低是O(n2)。其原因是,当前一次循环已求出7!,当这次要想求9!时,没必要再从1去

4、累乘到9,只需要充分利用前一次的结果,用7!*8*9即可得到9!,模型为An=An-1*1/((2*n-2)*(2*n-1)。另外运算sign=sign*(-1);总共也要进行n*(n-1)/2次乘法,这也是没有必要的。下面我们就进行改进。数学模型2:Sn=Sn-1+(-1)n+1An; An=An-1*1/((2*n-2)*(2*n-1))main(){inti,n,sign;floats,t=1;input(n);s=1;sign=1;for(i=2;i<=n;i=i+1)或for(i=1;i

5、<=n-1;i=i+1){sign=-sign;{sign=-sign;t=t*(2*i-2)*(2*i-1)};t=t*2*i*(2*i+1)};s=s+sign/t;}s=s+sign/t;}print(“Sum=”,s);}算法说明2:构造循环不变式时,一定要注意循环变量的意义,如当i不是项数序号时(右边的循环中)有关t的累乘式与i是项数序号时就不能相同。算法分析:按照数学模型2,只需一重循环就能解决问题算法的时间复杂性为O(n)。2.“自顶向下”的设计方法自顶向下的方法是从全局走向局部、从

6、概略走向详尽的设计方法。自上而下是系统分解和细化的过程。【例2】编算法找出1000以内所有完数例如,28的因子为1、2、4、7,14,而28=1+2+4+7+14。因此28是“完数”。编算法找出1000之内的所有完数,并按下面格式输出其因子:28it’sfactorsare1,2,4,7,14。1)这里不是要质因数,所以找到因数后也无需将其从数据中“除掉”。2)每个因数只记一次,如8的因数为1,2,4而不是1,2,2,2,4。(注:本题限定因数不包括这个数本身)1)顶层算法for(i=0;i

7、i=i+1){找第i行上最小的元素t及所在列minj;检验t是否第minj列的最大值,是则输出这个鞍点;}2)找第i行上最小的元素t及所在列minjt=a[i][0];minj=1;for(j=1;j

8、结果,应该开辟数组存储数据i的所有因子,并记录其因子的个数,因此算法细化如下:定义数组a,s=1;k=0;for(j=2;j

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

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

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