python输出递归树_Python树遍历递归深度超出

我有一个段树,它保存一系列数字的数据(数据结构选择here).这是代码:

class SegmentTree:

def __init__(self, N):

def _init(b, e):

if b is e:

data = foo() # No dependency

return Node(b, e, data, None, None)

else:

mid = (b + e ) / 2

L = _init(b, mid)

R = _init(mid + 1, e)

data = foo() #Data depends on L and R

return Node(b, e, data, L, R)

self.root = _init(1, N)

对于大约300的N,超过最大递归深度超出错误时,这会失败.有没有办法迭代地而不是递归地创建树?

解决方法:

真正的问题不是算法的递归深度,对于像300这样的值,它应该是大约10,但是你要将数字与is进行比较. is关键字检查对象标识,而==检查相等性:

>>> 300 == 299+1

True

>>> 300 is 299+1

False

因为你的if条件应该终止递归永远不会成立,函数将继续递归,即使b和e相等.

如果你改变了,如果这个问题应该消失:

if b == e:

...

对于较小的数字,问题可能不会发生,因为Python “caches” and reuses the objects的内容达到一定的大小.

标签:python,algorithm,optimization,tree

来源: https://codeday.me/bug/20190729/1576455.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值