python中的函数递归

函数递归,就是一个函数,自己调用自己。

如上图所示,是一段通过定义函数,编写函数体来实现for循环。实现的是从1到n的累乘。即求n的阶乘,

如上图所示,是一段函数的递归来实现1到n的累乘操作,将1****n拆分成一个个的子问题,如果条件是1时就返回1,如果条件不是1时,就return n * factor(n - 1)将n的值一步步衰减。

递归的代码,虽然很多时候看起来写法很简单,但是执行过程可能会非常复杂!!

在分析递归代码的时候,光用脑子想,是很困难!!

要么画图,要么使用调试器,来一步步的查看代码的运行情况。

如果递归函数的递推公式写错,那么就可能出现无限递归的情况,造成栈溢出(即这块内存空间用来储存变量的值是不够的,由此出现栈溢出的情况。)

递归的优点:代码非常简洁,尤其是处理一些"问题本身就是通过递归的方式定义的"

相关推荐
建群新人小猿几秒前
陀螺匠企业助手——组织框架图
android·java·大数据·开发语言·容器
CV_J1 分钟前
索引库操作
java·开发语言·elasticsearch·spring cloud
阿蒙Amon2 分钟前
C#每日面试题-简述异常处理
开发语言·c#
敲敲千反田24 分钟前
多线程复习
java·开发语言
APIshop1 小时前
Java获取item_get-获得某书商品详情接口
java·开发语言·python
SNAKEpc121381 小时前
深入理解PyQtGraph核心组件交互
python·qt·pyqt
Henry Zhu1231 小时前
Qt Model/View架构详解(四):高级特性
开发语言·qt·架构
txinyu的博客2 小时前
std::function
服务器·开发语言·c++
人工智能AI技术2 小时前
【Agent从入门到实践】25 主流向量数据库速览:Pinecone、Chroma、Milvus,本地/云端选型建议
人工智能·python
多多*2 小时前
图解Redis的分布式锁的历程 从单机到集群
java·开发语言·javascript·vue.js·spring·tomcat·maven