首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >只是无的二叉树可以被认为是最小堆树吗?

只是无的二叉树可以被认为是最小堆树吗?
EN

Stack Overflow用户
提问于 2015-05-17 02:53:28
回答 3查看 254关注 0票数 1

我需要为一个最小堆二进制树编写一个递归来检查这个树是否是最小堆。其中一个测试用例就是“无”。

是否将None视为最小堆树并返回True,或者NoneFalse

我询问的原因是,我将在某个时刻到达叶子,它们的节点是None,如果基例是True,那么它将返回True

EN

回答 3

Stack Overflow用户

发布于 2015-05-17 02:56:20

我相信none类型将是空的,因为它不违反min-heap树的定义。

票数 1
EN

Stack Overflow用户

发布于 2015-05-17 02:56:10

是的,没有一个被认为是均值堆树。

票数 0
EN

Stack Overflow用户

发布于 2015-05-17 03:36:20

你的意思一定是最小的堆。当我们处理任何树结构时,Node的子节点通常被初始化为None。的原因之一是我们可以很容易地避开递归,如下:

代码语言:javascript
复制
def find_node(node, data):
   if root is None:
      return
   if root.data == data:
       print "Node found"
   find_node(node.left, data)
   find_node(node.right, data)



class Node(object):

    def __init__(self, data):
       self.left = None
       self.right = None
       self.data = data

在您的例子中,您希望通过遍历树来检查它是否是最小堆。你会做这样的事

代码语言:javascript
复制
def is_min_heap(root):
  #.....check here and then do
  return is_min_heap(root.left) and is_min_heap(root.right)

但这取决于你想要如何处理它。任何没有子节点的节点都是min-heap或max-heap,但它没有任何意义。如果你想打电话给

is_min_heap(None),那么你可以自由地这样做,但这取决于你是否想说这是真的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30279549

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档