python的递归女神自拍_Python lambda匿名递归

Python的lambda表达式构成的匿名函数只能有一条表达式,而且不能引用自身.

想要在lambda表达式中实现匿名递归就需要在表达式中创造一条新的lambda表达式以实现递归,所以我们需要两条lambda表达式.

一个简单的字典递归穷举算法:

def func(str,len):

if len==1:

return [a for a in str]

else:

return [a+b for a in str for b in func(str,len-1)]

func('123',3)

#['111', '112', '113', '121', '122', '123', '131', '132', '133',

# '211', '212', '213', '221', '222', '223', '231', '232', '233',

# '311', '312', '313', '321', '322', '323', '331', '332', '333']

将其转化为lambda表达式应为(因为单行代码太长会超出页面显示范围,所以改写成多行的形式):

func=lambda str,len

:[a for a in str] if len==1 else [a+b for a in str for b in func(str,len-1)]

func('123',3)

这还没有实现匿名递归,因为func作为一个函数对象暴露在了全局作用域中.

要彻底将func隐藏,需要写另一条lambda表达式:

lambda str,len,func:func(str,len,func)

在这段lambda表达式中func成为了匿名函数的一个参数.

把这段代码和func函数组合起来:

lambda str,len,

func=lambda str,len,func

:[a for a in str] if len==1 else [a+b for a in str for b in func(str,len-1,func)]

:func(str,len,func)

现在func不会暴露在全局作用域中了,看看执行结果:

>>> (lambda str,len,

func=lambda str,len,func

:[a for a in str] if len==1 else [a+b for a in str for b in func(str,len-1,func)]

:func(str,len,func)

)('123',3)

['111', '112', '113', '121', '122', '123', '131', '132', '133',

'211', '212', '213', '221', '222', '223', '231', '232', '233',

'311', '312', '313', '321', '322', '323', '331', '332', '333']

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值