python中的函数递归

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

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

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

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

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

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

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

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

相关推荐
就叫飞六吧13 小时前
QT写一个桌面程序exe并动态打包基本流程(c++)
开发语言·c++
threelab13 小时前
Three.js 代码云效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
V搜xhliang024613 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
kaikaile199513 小时前
风、浪、流环境模型的船舶三自由度(纵荡、横荡、艏摇)运动仿真MATLAB
开发语言·人工智能·matlab
fish_xk13 小时前
map和set
java·开发语言
李崧正14 小时前
Java技术分享:Lambda表达式与函数式编程
java·开发语言·python
老了,不知天命14 小时前
鳶尾花項目JAVA
java·开发语言·机器学习
BIGmustang14 小时前
python练手之用tkinter写一个计算器
开发语言·python
winner888114 小时前
从零吃透C++命名空间、std、#include、string、vector
java·开发语言·c++
WL_Aurora14 小时前
Python 算法基础篇之链表
python·算法·链表