递归算法在程序设计语言中广泛应用。是指函数/过程/子程序在运行过程中直接或间接调用自身而产生的现象。采用递归编写程序能使程序变得简洁和清晰。递归要求
1递归结束条件及结束时的值递归出口
2能用递归形式表示且递归向终止条件发展问题简化语句规模递减
例4.18利用函数的递归调用求n 。
function f=factor(n)%最好不要取此函数名if n<=1f=1;elsef=factor(n-1)*n; %递归调用求(n-1)!endnote系统采用递归工作栈来实现。 Matlab递归深度为500。
运行效率比较低。
迭代算法是用计算机解决问题的一种基本方法。它利用计算机运算速度快、适合做重复性操作的特点让计算机对一组指令(或一定步骤)进行重复执行在每次执行这组指令(或这些步骤)时都从变量的原值推出它的一个新值。
利用迭代算法解决问题需要做好以下三个方面的工作
第一确定迭代变量
在可以用迭代算法解决的问题中至少存在一个直接或间接地不断由旧值递推出新值的变量这个变量就是迭代变量。
第二建立迭代关系式
所谓迭代关系式指如何从变量的前一个值推出其下一个值的公式(或关系) 。迭代关系式的建立是解决迭代问题的关键通常可以使用递推或倒推的方法来完成。
第三对迭代过程进行控制
在什么时候结束迭代过程?不能让迭代过程无休止地重复执行下去。迭代过程的控制通常可分为两种情况一种是所需的迭代次数是个确定的值可以计算出来;另一种是所需的迭代次数无法确定。对于前一种情况可以构建一个固定次数的循环来实现对迭代过程的控制;对于后一种情况需要进一步分析出用来结束迭代过程的条件。
实验四3考虑以下迭代公式xn+1=a/(b+xn) , 其中a b为正的常数。
(1)编写程序求迭代的结果迭代的终止条件为|xn+1-xn|≤10-5
迭代初值x0=1 .0,迭代次数不超过500次。a=input( 'a=?' ) ;b=input( 'b=?' ) ;
X0=1.0;%迭代变量,确定初值
X1=a/ (b+X0) ;n=1;while abs (X1-X0)>1e-5 %终止条件
X0=X1;
X1=a/ (b+X0) ;%迭代关系式n=n+1;if n==500%终止条件break;endendn
X1r1=(-b+sqrt(b*b+4*a) ) /2r2=(-b-sqrt(b*b+4*a) ) /2note方程x2+bx-a=0之根。
EdgeNat 商家在之前也有分享过几次活动,主要提供香港和韩国的VPS主机,分别在沙田和首尔LG机房,服务器均为自营硬件,电信CN2线路,移动联通BGP直连,其中VPS主机基于KVM架构,宿主机采用四路E5处理器、raid10+BBU固态硬盘!最高可以提供500Gbps DDoS防御。这次开年活动中有提供七折优惠的韩国独立服务器,原生IP地址CN2线路。第一、优惠券活动EdgeNat优惠码(限月...
LOCVPS在农历新年之后新上架了日本大阪机房软银线路VPS主机,基于KVM架构,配备原生IP,适用全场8折优惠码,最低2GB内存套餐优惠后每月仅76元起。LOCVPS是一家成立于2012年的国人VPS服务商,提供中国香港、韩国、美国、日本、新加坡、德国、荷兰、俄罗斯等地区VPS服务器,基于KVM或XEN架构(推荐选择KVM),线路方面均选择国内直连或优化方案,访问延迟低,适合建站或远程办公使用。...
优林怎么样?优林好不好?优林 是一家国人VPS主机商,成立于2016年,主营国内外服务器产品。云服务器基于hyper-v和kvm虚拟架构,国内速度还不错。今天优林给我们带来促销的是国内东北地区哈尔滨云服务器!全部是独享带宽!首月5折 续费5折续费!地区CPU内存硬盘带宽价格购买哈尔滨电信2核2G50G1M53元直达链接哈尔滨电信4核4G50G1M83元直达链接哈尔滨电信8核8G50G1M131元直...