python递归是什么意思_有人可以解释双递归python吗?

这是检测递归代码的简单方法

import inspect

def f(s):

print " " * (len(inspect.stack())-2), '>>', s

if len(s) <= 1:

print " " * (len(inspect.stack())-2), '<<', s

return s

else:

retval = f(f(s[1:])) + s[0] #Note double recursion

print " " * (len(inspect.stack())-2), '<<', retval

return retval

print f('world')

版画

>> world

>> orld

>> rld

>> ld

>> d

<< d

>> d

<< d

<< dl

>> dl

>> l

<< l

>> l

<< l

<< ld

<< ldr

>> ldr

>> dr

>> r

<< r

>> r

<< r

<< rd

>> rd

>> d

<< d

>> d

<< d

<< dr

<< drl

<< drlo

>> drlo

>> rlo

>> lo

>> o

<< o

>> o

<< o

<< ol

>> ol

>> l

<< l

>> l

<< l

<< lo

<< lor

>> lor

>> or

>> r

<< r

>> r

<< r

<< ro

>> ro

>> o

<< o

>> o

<< o

<< or

<< orl

<< orld

<< orldw

orldw

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值