用递归法解决问题.ppt

用递归法解决问题.ppt

ID:52513675

大小:225.51 KB

页数:16页

时间:2020-04-09

用递归法解决问题.ppt_第1页
用递归法解决问题.ppt_第2页
用递归法解决问题.ppt_第3页
用递归法解决问题.ppt_第4页
用递归法解决问题.ppt_第5页
资源描述:

《用递归法解决问题.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、3.5用递归法解决问题徐州第二十六中学朱九妹“从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山

2、,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲什么呢?”…………故事这个故事有什么特点?自己调用自己如果在一个函数中,它自己调用了自己,这种现象叫递归调用。如果A函数调用B函数,B函数又反过来调用A函数,那这种现象也叫做递归调用。如果一个函数在定义时,直接或间接的调用了自己,这种算法在程序设计中统称为递归法。递归算法的基本思想是:把规模大的、较难解决的问题变成规模较小的、易

3、解决的同一问题。规模较小的问题又变成规模更小的问题,并且小到一定程度可以直接得出它的解,从而得到原来问题的解。子程序中定义递归调用。一般格式为:if边界条件1成立then赋予边界值1[elseif边界条件2成立then赋予边界值2┇]else调用解决问题的通式endif自定义函数递归法一般需要定义函数来实现。这里所讲的函数是自定义函数。虽然VB为我们提供了大量的标准函数,但我们在实际应用时难免有时还是找不到合意的,那就只有自己解决了,这样为了一个特定的任务而编出来的函数叫自定义函数。Abs()、le

4、n()、date()、sqr()、msgbox()等二、自定义函数的作用1、可以方便的把较为复杂的问题分解成若干个小问题去处理。(公司里就是采用这中模式的。)2、使程序结构清晰,层次分明,增强了程序的可读性。一、标准函数VB给我们提供了一些标准函数,我们不用了解这些函数如何求出来的,只管直接调用它们,挺方便的。如正弦函数,余弦函数,算术平方根......有了这些函数,我们觉得很省事。如:求1加到100的算术平方根这个程序我们可以这样编写:例1dimIasinteger,sassingles=0for

5、i=1to100dos=s+sqr(i)nextiprint“s=”;s在这个程序里,我们直接用到了求平方根函数,至于sqr(1),sqr(2)如何求出来的我们不需过问,只管直接用它的结果便是了。象这样,VB给我们提供的,我们不用了解这些函数如何求出来的,只管直接调用它们的这类函数叫做标准函数。二、用户自定义函数我们来看看下面一个例子:求:1!+2!+3!+...+10!=?如果要编写程序,我们看到求阶乘的操作要执行10次,只不过每次所求的数不同。我们想:不至于编写10遍求阶乘的程序吧。我们希望有一

6、个求阶乘的函数,假设为JS(X),那么我们就可以这样求这道题了:例2dimIasinteger,jasintegerdimsasintegers=0fori=1to10dos=s+js(i)nextiprint“s=“;s现在的问题是:VB没提供JS(X)这样一个标准函数,这个程序是通不过的。如果是PASCAL的标准函数,我们可以直接调用,如前面的sqr(i),而PASCAL提供给我们的可供直接调用的标准函数不多。没关系,我们编写自己的函数!三、函数编写在VB中,自定义函数形式如下:[Public|

7、Private]Function<函数名称>([参数列表])[As类型]局部常量、变量定义语句组函数名称=返回值EndFunctionPublic(公共的)-----全局变量,指在所有程序(包括主程序和过程)中都可以使用的内存变量.Private(私人的)-----局部变量,用private语句声明的变量可被本窗体/模块的任何过程访问,但其他模块却不能访问该变量.参数列表:[ByVal

8、ByRef]变量名[()][As类型]表示该参数按值传递不会修改变量原来的值表示该参数按地址传递会直接改变原来的变

9、量值例3编写一求阶乘的函数。我们给此函数取一名字就叫JS。fUNCTIONjs(nasinteger)asintegerdimIasinteger,sasintegers=1fori=1tondos=s*inextijs=send自定义函数的调用,可以有三种格式:格式一:变量=函数名称(参数)格式二:Call函数名称(参数)格式三:函数名称参数使用递归算法大致结构为:(1)递归出口(2)递归体一个递归算法,当其问题求解的规模越来越小时必定有一个递归出口,就是不再递归调

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

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

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