欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    Python基础教程、Python入门教程之递归算法.doc

    • 资源ID:12997693       资源大小:23KB        全文页数:4页
    • 资源格式: DOC        下载积分:6金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要6金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Python基础教程、Python入门教程之递归算法.doc

    . .Python基础教程、Python入门教程之递归算法文章目录1. 递归概述2. 线性递归3. 尾递归4. 单向递归5. 深度优先与广度优先1. 递归概述递归( recursion)是一种编程技巧,某些情况下,甚至是无可替代的技巧。递归可以大幅简化代码,看起来非常简洁,但递归设计却非常抽象,不容易掌握。通常,我们都是自上而下的思考问题, 递归则是自下而上的解决问题这就是递归看起来不够直观的原因。那么,究竟什么是递归呢?让我们先从生活中找一个栗子。我们都有在黑暗的放映厅里找座位的经验:问问前排的朋友坐的是第几排,加上一,就是自己当前所处位置的排号。如果前排的朋友不知道自己是第几排,他可以用同样的方法得到自己的排号,然后再告诉你。如果前排的前排的朋友也不知道自己是第几排,他就如法炮制。这样的推导,不会无限制地进行下去,因为问到第一排的时候,坐在第一排的朋友一定会直接给出答案的。这就是递归算法在生活中的应用实例。关于递归,不太严谨的定义是“一个函数在运行时直接或间接地调用了自身”。严谨一点的话,一个递归函数必须满足下面两个条件:至少有一个明确的递归结束条件,我们称之为递归出口,也有人喜欢把该条件叫做递归基。有向递归出口方向靠近的直接或间接的自身调用(也被称作递归调用)。递归虽然晦涩,亦有规律可循。掌握了基本的递归理论,才有可能将其应用于复杂的算法设计中。2. 线性递归我们先从最经典的两个递归算法开始阶乘(factorial)和斐波那契数列(Fibonacci sequence)。几乎所有讨论递归算法的话题,都是从从它们开始的。阶乘的概念比较简单,唯一需要说明的是,0的阶乘是1而非0。为此,我专门请教了我的女儿,她是数学专业的学生。斐波那契数列,又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21、34、在数学上,斐波纳契数列是这样定义的:     F(0)=1,F(1)=1, F(n)=F(n-1)+F(n-2)(n>=2,nN,N为正整数集)1阶乘和斐波那契数列的递归算法如下:def factorial(n):     if n = 0: # 递归出口         return 1     return n*factorial(n-1) # 向递归出口方向靠近的自身调用def fibonacci(n):     if n < 2: # 递归出口         return 1     return fibonacci(n-1) + fibonacci(n-2) # 向递归出口方向靠近的自身调用这两个函数的结构都非常简单,递归出口和自身调用清晰明了,但二者有一个显著的区别:阶乘函数中,只用一次自身调用,而斐波那契函数则有两次自身调用。阶乘递归函数每一层的递归对自身的调用只有一次,因此每一层次上至多只有一个实例,且它们构成一个线性的次序关系。此类递归模式称作“线性递归”,这是递归最基本形式。非线性递归(比如斐波那契递归函数)在每一层上都会产生两个实例,时间复杂度为O(n2) O(n2)O(n 2),极易导致堆栈溢出。其实,用循环的方法同样可以简洁地写出上面两个函数。的确,很多情况下,递归能够解决的问题,循环也可以做到。但是,更多的情况下,循环是无法取代递归的。因此,深入研究递归理论是非常有必要的。3. 尾递归接下来,我们将上面的阶乘递归函数改造一下,仍然用递归的方式实现。为了便于比较,我们把两种算法放在一起。def factorial_A(n):     if n = 0: # 递归出口         return 1     return n*factorial_A(n-1) # 向递归出口方向靠近的自身调用def factorial_B(n, k=1):     if n = 0: # 递归出口         return k     k *= n     n -= 1     return factorial_B(n,k) # 向递归出口方向靠近的自身调用比较 factorial_A() 和 factorial_B() 的写法,就会发现很有意思的问题。factorial_A() 的自身调用属于表达式的一部分,这意味着自身调用不是函数的最后一步,而是拿到自身调用的结果后,需要再做一次乘法运算;factorial_B() 的自身调用则是函数的最后一步。像 factorial_B() 函数这样,当自身调用是整个函数体中最后执行的语句,且它的返回值不属于表达式的一部分时,这个递归调用就是尾递归(Tail Recursion)。尾递归函数的特点是在回归过程中不用做任何操作,这个特性很重要,因为大多数现代的编译器会利用这种特点自动生成优化的代码。分别使用 factorial_A() 和 factorial_B() 计算5的阶乘,下图所示的计算过程,清晰展示了尾递归的优势:不用花费大量的栈空间来保存上次递归中的参数、局部变量等,这是因为上次递归操作结束后,已经将之前的数据计算出来,传递给当前的递归函数,这样上次递归中的局部变量和参数等就会被删除,释放空间,从而不会造成栈溢出。factorial_A(5)5 * factorial_A(4)5 * 4 * factorial_A(3)5 * 4 * 3 * factorial_A(2)5 * 4 * 3 * 2 * factorial_A(1)5 * 4 * 3 * 2 * 1 * factorial_A(0)5 * 4 * 3 * 2 * 15 * 4 * 3 * 25 * 4 * 65 * 24120factorial_B(5, k=1)factorial_B(4, k=5)factorial_B(3, k=20)factorial_B(2, k=60)factorial_B(1, k=120)factorial_B(0, k=120)120尾递归虽然有低耗高效的优势,但这一类递归一般都可转化为循环语句。4. 单向递归前文中两个递归函数,不管是阶乘还是斐波那契数列,递归总是向着递归出口方向进行,没有分支,没有反复,这样的递归,我们称之为单向递归。在文件递归遍历等应用场合,搜索完一个文件夹,通常要返回至父级目录,继续搜索其他兄弟文件夹,这个过程就不是单向的,而是有分叉的、带回溯的。通常复杂递归都不是单向的,算法设计起来就比较困难。import osdef ergodic(folder):     for root, dirs, files in os.walk(folder):         for dir_name in dirs:             print(os.path.join(root, dir_name)         for file_name in files:             print(os.path.join(root, file_name)上面是借助于 os 模块的 walk() 实现的基于循环的文件遍历方法。虽然是循环结构,如果不熟悉 walk() 的话,这个函数看起来还是很不直观。我更喜欢下面的递归遍历方法。import osdef ergodic(folder):     for item in os.listdir(folder):         obj = os.path.join(folder, item)         print(obj)         if os.path.isdir(obj):             ergodic(obj)5. 深度优先与广度优先遍历文件通常有两种策略:深度优先搜索 DFS(depth-first search) 和广度优先搜索BFS(breadth-first search) 。顾名思义,深度优先就是优先处理本级文件夹中的子文件夹,递归向纵深发展;广度优先就是优先处理本级文件夹中的文件,递归向水平方向发展。import osdef ergodic_DFS(folder):     """基于深度优先的文件遍历"""          dirs, files = list(), list()     for item in os.listdir(folder):         if os.path.isdir(os.path.join(folder, item):             dirs.append(item)         else:             files.append(item)          for dir_name in dirs:         ergodic(os.path.join(folder, dir_name)     for file_name  in files         print(os.path.join(folder, file_name)def ergodic_BFS(folder):     """基于广度优先的文件遍历"""          dirs, files = list(), list()     for item in os.listdir(folder):         if os.path.isdir(os.path.join(folder, item):             dirs.append(item)         else:             files.append(item)          for file_name  in files         print(os.path.join(folder, file_name)     for dir_name in dirs:         ergodic(os.path.join(folder, dir_name)黑马程序员视频库网址:yun.itheima.(海量热门编程视频、资料免费学习)学习路线图、学习大纲、各阶段知识点、资料网盘免费领取+QQ 3285264708 / 3549664195. .jz.

    注意事项

    本文(Python基础教程、Python入门教程之递归算法.doc)为本站会员(知****量)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开