12.python的函数(三)—递归函数

接下来是递归函数,递归在C语言中也是很重要的一种思想。示例代码如下:

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
def func(n):
    if n==1:
        return 1
    else:
        return n*func(n-1)
print(func(6))

使用递归的时候,尽量避免次数过多。根据数据结构,我们知道。调用函数,是通过栈来操作的。一旦,次数过多的话,栈空间不够用。这样容易造成内存溢出。

要想解决这个问题我们可以通过尾递归优化。尾递归指的是,在函数返回的时候,调用自身本身。并且return 语句,不能包含表达式。这样每次调用就会只占用一个栈帧。因为,python对尾递归并未做优化。故而,这里不做详述。只给出示例代码:

def fact(n):
    return fact_iter(n, 1)

def fact_iter(num, product):
    if num == 1:
        return product
    return fact_iter(num - 1, num * product)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值