iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >什么是python尾递归
  • 923
分享到

什么是python尾递归

2024-04-02 19:04:59 923人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

本篇内容主要讲解“什么是python尾递归”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是Python尾递归”吧!递归是啥?递归函数大家肯定写过,学校上课的

本篇内容主要讲解“什么是python递归”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是Python尾递归”吧!

递归是啥?

递归函数大家肯定写过,学校上课的时候,估计最开始的例子就是斐波拉契数列了吧。例如:

int Fibonacci(n) {     if (n < 2) return n;     return Fibonacci(n - 1) + Fibonacci(n - 2); }

递归函数简而言之就是在一个函数中,又“递归”调用自己。在写递归函数的时候,需要注意的地方就是递归函数的结束条件。用递归函数确实能简化很多算法的实现,比如常见的二叉树遍历等。但往往在写递归函数的时候,最容易出现的问题就是所谓的“栈溢出”。

为什么会有“栈溢出”呢?因为函数调用的过程,都要借助“栈”这种存储结构来保存运行时的一些状态,比如函数调用过程中的变量拷贝,函数调用的地址等等。而“栈”往往存储空间是有限的,当超过其存储空间后,就会抛出著名的异常/错误“StackOverflowError”。

我们以一个简单的加法为例,例如:

int sum(int n) {     if (n <= 1) return n;     return n + sum(n-1); }  std::cout << sum(100) << std::endl; std::cout << sum(1000000) << std::endl;

很简答,编译运行后,比较小的数字,能得到正确的答案,当数字扩大后,就会直接发生“segmentation fault”。

尾递归又是啥?

我得知这个概念,最开始还是因为很多年前一次面试,面试官问我“你知道什么是尾递归吗?”,我以为是“伪”递归,难道是假的递归???当初我也是懵逼状态(当初面试官忍住没笑也是厉害了)。从“尾”字可看出来即若函数在尾巴的地方递归调用自己。上面的例子写成尾递归,就变成了如下:

int tailsum(int n, int sum) {     if (n == 0) return sum;     return tailsum(n-1, sum+n); }

可以试试结果,计算从 1 加到 1000000,仍然是segmentation  fault。为什么呢?因为这种写法,本质上还是有多层的函数嵌套调用,中间仍然有压栈、出栈等占用了存储空间(只不过能比前面的方法会省部分空间)。

尾递归优化

当你给编译选项开了优化之后,见证奇迹的时刻到了,居然能算出正确结果。如图所示:

什么是python尾递归

c++ 默认 segmentation fault, 开启编译优化后,能正常计算结果。

原因就是因为编译器帮助做了尾递归优化,可以打开汇编代码看看(这里就不展示 C++的了)。后面我用大家比较熟悉的 JVM based 语言 Scala  来阐述这个优化过程。(好像 Java 的编译器没做这方面的优化,至少我实验我本地 jdk8 是没有的,不清楚最新版本的有木有)(scala  本身提供了一个注解帮助编译器强制校验是否能够进行尾递归优化@tailrec)

object TailRecObject {     def tailSum(n: Int, sum: Int): Int = {         if (n == 0) return sum;         return tailSum(n-1, n+sum);    }     def main(args: Array[String]) {       println(tailSum(100, 0))       println(tailSum(1000000, 0))    }  }

结果如下图所示,默认情况下 scalac 做了尾递归优化,能够正确计算出结果,当通过 -g:notailcalls 编译参数去掉尾递归优化后,就发生了  Exception in thread "main" java.lang.StackOverflowError了。

什么是python尾递归

默认启用尾递归优化正常计算结果,禁用尾递归优化则“StackOverflow”。

我们来看看生成的字节码有什么不同。

什么是python尾递归

包含尾递归优化的字节码,直接 Goto 循环。

什么是python尾递归

禁用尾递归优化的字节码,方法调用。

从上面可以看出,尾递归优化后,变成循环了(前面的 C++ 类似)。

到此,相信大家对“什么是python尾递归”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 什么是python尾递归

本文链接: https://www.lsjlt.com/news/84960.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 什么是python尾递归
    本篇内容主要讲解“什么是python尾递归”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是python尾递归”吧!递归是啥递归函数大家肯定写过,学校上课的时...
    99+
    2024-04-02
  • python怎么实现尾递归优化
    小编给大家分享一下python怎么实现尾递归优化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!说明尾递归是指在函数返回时调用自身,return语句不能包含表达式。...
    99+
    2023-06-20
  • Python怎么开启尾递归优化
    这篇文章主要讲解了“Python怎么开启尾递归优化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python怎么开启尾递归优化”吧!一般递归与尾递归一般递归:def normal_...
    99+
    2023-06-30
  • C++ 函数尾递归优化的条件是什么?
    c++++ 中尾递归优化 (tco) 的条件如下:尾递归调用必须是函数的最后一个动作。函数的参数和局部变量在尾递归调用中必须保持不变。编译器必须支持 tco。实战案例中,使用 tco 将...
    99+
    2024-04-11
    c++ 函数尾递归优化
  • C++ 函数递归详解:尾递归优化
    递归定义及优化:递归:函数内部调用自身,解决可分解为更小子问题的难题。尾递归:函数进行所有计算后才进行递归调用,可优化为循环。尾递归优化条件:递归调用为最后操作。递归调用参数与原始调用参...
    99+
    2024-05-03
    c++ 递归
  • python中什么是递归算法
    本篇文章为大家展示了python中什么是递归算法,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python主要应用领域有哪些1、云计算,典型应用OpenStack。2、WEB前端开发,众多大型网站均...
    99+
    2023-06-14
  • javascript不支持尾递归吗
    尾递归是一种算法优化技术,可以将递归算法转化为效率更高的迭代算法。尾递归相对于常规递归而言,可以极大地减小栈的深度,从而避免栈溢出等问题。然而,JavaScript 并不支持尾递归,这对于很多工程实践而言是一个问题。为什么 JavaScri...
    99+
    2023-05-14
  • Javascript尾递归编程怎么实现
    本篇内容介绍了“Javascript尾递归编程怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!尾递归编程思想递归是编程中必不可少的一环...
    99+
    2023-07-02
  • Javascript尾递归编程的实现
    目录尾递归编程思想最容易的递归运用缓存结果思想解决函数开销迭代方法尾递归实现原理图解关于Javascript没有实现尾递归优化trampoline实现尾递归编程思想 递归是编程中必不...
    99+
    2024-04-02
  • C++ 递归进阶:理解尾递归优化及其应用
    尾递归优化 (tro) 可提高特定递归调用的效率。它将尾递归调用转换为跳转指令,并将上下文状态保存在寄存器中,而不是堆栈上,从而消除对堆栈的额外调用和返回操作,提高算法效率。利用 tro...
    99+
    2024-04-30
    c++ 递归
  • 详解Python如何实现尾递归优化
    目录一般递归与尾递归一般递归尾递归C中尾递归的优化Python开启尾递归优化一般递归与尾递归 一般递归 def normal_recursion(n): if n == 1:...
    99+
    2024-04-02
  • 尾递归详细总结分析
    一. 尾递归与Continuation递归与尾递归关于递归操作,相信大家都已经不陌生。简单地说,一个函数直接或间接地调用自身,是为直接或间接递归。例如,我们可以使用递归来计算一个单向...
    99+
    2022-11-15
    尾递归
  • python中的递归函数是什么
    这篇文章将为大家详细讲解有关python中的递归函数是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Python的优点有哪些1、简单易用,与C/C++、Java、C# 等传统语言相比,Python对代...
    99+
    2023-06-14
  • Python开启尾递归优化的实现示例
    目录一般递归与尾递归一般递归:尾递归C中尾递归的优化Python开启尾递归优化一般递归与尾递归 一般递归: def normal_recursion(n): if n == ...
    99+
    2024-04-02
  • 什么是递归算法
    这篇文章主要介绍“什么是递归算法”,在日常操作中,相信很多人在什么是递归算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”什么是递归算法”的疑惑有所帮助!接下来,请跟着小编一...
    99+
    2024-04-02
  • C++ 递归函数的尾递归优化策略如何实现?
    尾递归优化策略通过将尾递归调用转换为循环,有效减少函数调用栈深度,防止栈溢出。优化策略包括:检测尾递归:检查函数中是否存在尾递归调用。将函数转换为循环:使用循环来代替尾递归调用,并维护栈...
    99+
    2024-04-17
    递归函数 尾递归优化 c++
  • Python函数的递归方法是什么
    本篇内容介绍了“Python函数的递归方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!函数调用自身的 编程技巧 称为递归。1.1、递...
    99+
    2023-06-22
  • python递归函数的特点是什么
    Python递归函数的特点包括:1. 函数可以调用自身:递归函数可以在函数体内直接调用自身,从而实现对问题的重复求解。2. 递归函数...
    99+
    2023-08-29
    python
  • python递归优化的方法是什么
    在Python中,递归函数的优化方法主要有以下几种:1、尾递归优化尾递归是指递归函数在递归调用时,最后一个操作是函数调用本身,可以通...
    99+
    2023-05-13
    python递归优化 python
  • C++ 递归与尾递归:性能差异和优化实践探讨
    c++++ 中标准递归会产生栈空间和时间开销,而尾递归不会。优化实践包括识别尾递归、转化为尾递归和启用编译器支持。尾递归比标准递归性能更高,因为它避免了创建额外活动记录和相关的开销。 ...
    99+
    2024-05-04
    c++ 递归 优化实践
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作