递归算法复习过程_第1页
递归算法复习过程_第2页
递归算法复习过程_第3页
递归算法复习过程_第4页
递归算法复习过程_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

递归算法情景2:镜子A和镜子B相对放在一起,你会发现什么现象呢?对了,我们会发现镜子A中有镜子B的映象,镜子B中又镜子A的映象,这样层层叠叠,无穷无尽。AB在程序设计中,像这种函数A调用函数B,函数B再反过来调用函数A的算法,也称为递归算法。递归的定义:如果一个函数在定义时,直接或者间接地调用了自己,这种算法在程序中统称为递归法。情景中的现象是无穷无尽的,然而,程序中,递归是有终点的。使用递归的条件递归算法——利用函数反复调用本身的算法。Functionthird(aasinteger,basinteger)third=sqr(a*a+b*b)EndFunctionFunctions(nasinteger)

s=s(n-1)+2Endfunction自定义函数中调用VB标准函数自定义函数中调用本身使用递归的两个条件:

2、有结束条件

1、在计算过程中,前后数据有一定的递推关系

1,2,4,7,11,16,22,29,37……..n=1时,a(n)=1n>1时,a(n)=a(n-1)+n-1递归算法实例

给定n(n>=1),用自定义函数的方法求

S(n)=1+2+3+4+……+n的值递推关系:S(n)和S(n-1)的递推关系?s(n)=s(n-1)+ns(5)=s(4)+5s(4)=s(3)+4s(3)=s(2)+3s(2)=s(1)+2s(1)=1n=1时,s值为1n>1时,s=s(n-1)+nPrivateSubCommand1_Click()DimnAsInteger

n=Val(InputBox("请输入n的值"))

Sum=s(n)PrintSumEndSubPublicFunctions(nAsInteger)AsIntegerIfn=1Then

s=1Else

s=s(n-1)+nEndIfEndFunction递归函数的定义递归函数的调用程序运行练习1:求阶乘用自定义递归函数的方法求S=N!

(N由用户手动输入文本框)N!指N的阶乘,如:8!=1*2*3*4*5*6*7*8函数名为S练习2:斐波那契数列斐波那契数列有如下特征:1、1、2、3、5、8、13、21、34......

用自定义递归函数的方法求该数列的前20项。

分析:前两项为1,从第子三项开始,S(n)=S(n-1)+S(n-2)函数名为fib汉诺塔DimnoAsIntegerPrivateSubhannuo(n,a,c,b)Ifn=1Thenno=no+1PrintStr(no);a;"-->";cList1.AddItemStr(no)+a+"-->"+cElseCallhannuo(n-1,a,b,c)Callhannuo(1,a,c,b)Callhannuo(n-1,b,c,a)EndIfEndSubPrivateSubCommand1_Click()DimnAsIntegern=Int(Val(InputBox("输入n")))

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论