扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
能力有限,仅知几点
创新互联公司是一家以成都网站建设、网页设计、品牌设计、软件运维、seo优化、小程序App开发等移动开发为一体互联网公司。已累计为护栏打桩机等众行业中小客户提供优质的互联网建站和软件开发服务。
两者都是重复某一操作直到满足条件为止。
不同之处在于,递归是函数调用自身,而迭代是使用循环。
某些情况下递归更加简单,可读性更高,而用循环则十分复杂。如二分法,快速排序等。
递归很容易导致栈溢出,导致程序崩溃,而循环不会。
综上所述,能用循环用循环,递归是万不得已的手段。
额,抽象的说就是解决一个问题时重复使用一个动作,那么就可以用递归的方式来解决,告诉电脑重复做这个动作就行.结合看一些递归算法的简单程序,应该好懂些.
首先我们回答一下,你的这个题目中是有用到递归的。
我们先来了解下什么是递归:
递归的定义:直接或间接调用自己的函数成为递归函数(recursionfunction)。在求解某些具有随意性的复杂问题时经常使用递归,例如求解阶乘或者两个数的最大公约数等。因为这时解的具体“大小”不受限制,函数可以一直递归调用,直到问题解决。
递归的要求:递归函数必须定义一个终止条件;否则,函数就会“永远”递归下去,这意味着函数会一直调用自身直到程序栈耗尽,这种“永远”递归下去的现象叫做“无限递归错误”(infiniterecursion error)。
递归的特点:
1、在函数f()中,会对函数f()自己进行调用。
2、无限递归实际上是不允许的;递归函数必须定义一个终止条件,即什么情况下终止递归,终止继续调用自己,如果没有终止条件,那么函数将一直调用自己,知道程序栈耗尽,这时候等于是写了一个Bug!
3、 递归算法解题通常代码比较简洁,但不是很容易读懂。
4、 递归的调用需要建立大量的函数的副本,尤其是函数的参数,每一层递归调用时参数都是单独的占据内存空间,他们的地址是不同的,因此递归会消耗大量的时间和内存。而非递归函数虽然效率高,但相对比较难编程。
5、 递归函数分为调用和回退阶段,递归的回退顺序是它调用顺序的逆序。
如果以上对你有帮助,青采纳一下, 谢谢。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流