7.3 递归与变量作用域课件.ppt

  1. 1、本文档共40页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
7.3 递归与变量作用域课件

上节课复习;知识要点;7.5 递归过程(难点);1.递归的概念 ; 如果在嵌套调用的过程中调用的是过程自身,这种过程也叫递归过程。 递归是一种十分有用的程序设计技术。由于很多的数学模型和算法设计方法本来就是递归的。比如:求阶乘,求指数等。 用递归过程描述它们比用非递归方法 简洁易读,可理解性好, 算法的正确性证明也比较容易 ;2. 递归算法的结构;裴波拉契数列;3. (重点)递归算法的执行过程分析—以阶乘为例;调用阶乘的程序;Fact(3) If N = 1then Fact = 1 Else Fact = 3 * Fact(3-1) End If End Function ;练一练:1 Private Function f (ByVal n As Integer) As Long If n = 0 Or n = 1 Then f = 1 Else f = f(n-2)+ f (n - 1) End If Print f End Function 主调程序中:x=f(3)窗体打印几行,每行结果是什么?;Private Sub Command1_Click() Dim n As Integer n = 1 Call dg(n) End Sub Private Sub dg(n As Integer) If n > 3 Then Exit Sub Else dg (n + 1) End If print n End Sub;课堂练习:;Private Function f(n As Integer) As Long If n = 1 Then f = 0 ElseIf n = 2 Then f = 1 Else f = 2 * f(n - 1) - f(n - 2) End If End Function Private Sub Command1_Click() Dim n%, i%, s% n = Val(Text1.Text) For i = 1 To n s = s + f(i) Next i Text2.Text = Str(s) End Sub;4. 无限递归;Private Sub Command1_Click() Dim n As Integer n = 1 Call dg(n) End Sub Private Sub dg(n As Integer) print n If n > 3 Then Exit Sub Else dg (n + 1) End If End Sub;递归真题实例;Private Sub Command1_Click() fun 3 End Sub Public Function fun(m As Integer) As Integer Dim value As Integer If m = 0 Then value = 3 Else value = fun(m - 1) + 5 End If fun = value Print m, value End Function;7.6 变量的作用域;变量的作用域;;  因为局部变量只在声明它们的过程中才能被访问或改变该变量的值,别的过程不可访问。所以可以在不同的过程中声明相同名字的局部变量而互不影响。 ;;例: Dim n% Private Sub Form_Load() n= 10 End Sub Private Sub From_Click() Print “n=“;n End Sub;Option Explicit Dim TestString As String Private Sub Form_ Activate () Debug.Print "在Form_Activate 事件过程中"; TestString Call ShowTestString End Sub Private Sub Form_Load() TestString = "测试变量作用域" End Sub Private Sub ShowTestString() Debug.Print "在过程ShowTestString 中"; TestString End Sub ;;例子;等荡匿踊哆束鳃

文档评论(0)

baa89089 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档