编程中的递归算法有哪些优缺点?

如题所述

递归算法的优点是代码更简洁清晰,可读性更好。但是,递归的话函数调用是有开销的,而且递归的次数受堆栈大小的限制。时间和空间消耗比较大。每一次函数调用都需要在内存栈中分配空间以保存参数,返回地址以及临时变量,而且往栈里面压入数据和弹出都需要时间。另外递归会有重复的计算。递归本质是把一个问题分解为多个问题,如果这多个问题存在重复计算,有时候会随着n成指数增长。斐波那契的递归就是一个例子。递归还有栈溢出的问题,每个进程的栈容量是有限的。由于递归需要系统堆栈,所以空间消耗要比非递归代码要大很多。而且,如果递归深度太大,可能系统撑不住 。
温馨提示:答案为网友推荐,仅供参考
相似回答