Найти - Пользователи
Полная версия: Не могу разобраться с Бинарным деревом
Начало » Python для новичков » Не могу разобраться с Бинарным деревом
1
DimaHP
У меня снова возникли сложности, но уже с Бинарным деревом. Не могу разобраться, что надо добавить в class BinaryTree, чтобы мне принтовалось значения вершины дерева и ее корней. Выглядеть это должно примерно так:
2
3 4
5 6 7 8
Вот исходный код:
    

from collections import deque


class EmptyTree(object):
"""Represents an empty tree."""

# Supported methods

def isEmpty(self):
return True

def __str__(self):
return ""

def __iter__(self):
"""Iterator for the tree."""
return iter([])

def preorder(self, lyst):
return

def inorder(self, lyst):
return

def postorder(self, lyst):
return

class BinaryTree(object):
"""Represents a nonempty binary tree."""

# Singleton for all empty tree objects
THE_EMPTY_TREE = EmptyTree()

def __init__(self, item):
"""Creates a tree with
the given item at the root."""
self._root = item
self._left = BinaryTree.THE_EMPTY_TREE
self._right = BinaryTree.THE_EMPTY_TREE

def isEmpty(self):
return False

def getRoot(self):
return self._root

def getLeft(self):
return self._left

def getRight(self):
return self._right

def setRoot(self, item):
self._root = item

def setLeft(self, tree):
self._left = tree

def setRight(self, tree):
self._right = tree

def removeLeft(self):
left = self._left
self._left = BinaryTree.THE_EMPTY_TREE
return left

def removeRight(self):
right = self._right
self._right = BinaryTree.THE_EMPTY_TREE
return right

def __str__(self):
"""Returns a string representation of the tree
rotated 90 degrees to the left."""
def strHelper(tree, level):
result = ""
if not tree.isEmpty():
result += strHelper(tree.getRight(), level + 1)
result += "| " * level
result += str(tree.getRoot()) + "\n"
result += strHelper(tree.getLeft(), level + 1)
return result
return strHelper(self, 0)

def __iter__(self):
"""Iterator for the tree."""
lyst = []
self.inorder(lyst)
return iter(lyst)

def preorder(self, lyst):
"""Adds items to lyst during
a preorder traversal."""
lyst.append(self.getRoot())
self.getLeft().preorder(lyst)
self.getRight().preorder(lyst)

def inorder(self, lyst):
"""Adds items to lyst during
an inorder traversal."""
self.getLeft().inorder(lyst)
lyst.append(self.getRoot())
self.getRight().inorder(lyst)

def postorder(self, lyst):
"""Adds items to lystduring
a postorder traversal."""
self.getLeft().postorder(lyst)
self.getRight().postorder(lyst)
lyst.append(self.getRoot())

def levelorder(self, lyst):
"""Adds items to lyst during
a levelorder traversal."""
# levelsQueue = LinkedQueue()
levelsQueue = deque ([])
levelsQueue.append(self)
while levelsQueue != deque():
node = levelsQueue.popleft()
lyst.append(node.getRoot())
left = node.getLeft()
right = node.getRight()
if not left.isEmpty():
levelsQueue.append(left)
if not right.isEmpty():
levelsQueue.append(right)
Подскажите хотя бы туториал по этой теме или необходимую инфу, чтобы решить эту задачу. Не могу сообразить, как в задачу вставить вообще значения корней и вершины дерева.
Murderdoll666
Потдерживаю. Как, хотя-бы примерно выглядел бы метод?
This is a "lo-fi" version of our main content. To view the full version with more information, formatting and images, please click here.
Powered by DjangoBB