簡體   English   中英

遍歷二進制搜索樹Python

[英]Traversing a Binary Search Tree Python

我正在努力遍歷二叉搜索樹,我認為我的代碼正確,但是仍然遇到以下錯誤。

C:\Python33\python.exe "C:/Users/koopt_000/Desktop/College/Sophomore Semester 2/Computer Science 231/Chapter7/Test.py"
Traceback (most recent call last):
  File "C:/Users/koopt_000/Desktop/College/Sophomore Semester 2/Computer Science 231/Chapter7/Test.py", line 16, in <module>
    print(BST.preOrder(tree))
TypeError: preOrder() missing 1 required positional argument: 'tree'

Process finished with exit code 1

我正在嘗試打印我的樹的預定順序,但它不想工作,這是我的代碼。

class TreeNode(object):

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

        self.item = data
        self.left = left
        self.right = right

    def __str__(self):
        return str(self.item)


#------------------------------------------------------------

from TreeNode import TreeNode


class BST(object):

    #------------------------------------------------------------

    def __init__(self):



        self.root = None
        self.size = 0

    #------------------------------------------------------------

    def preOrder(self, tree):
        if tree is None:
            pass
        else:
            print(tree.item)
            preOrder(tree.left)
            preOrder(tree.right)

    def postOrder(self, root):
        if root is None:
            pass
        else:
            self.postOrder(root.left)
            self.postOrder(root.right)
            print(root.item)

    def inOrder(self, root):
        if root is None:
            pass
        else:
            self.inOrder(root.left)
            print(root.item)
            self.inOrder(root.right)

這是我的測試代碼:

from BinarySearchTree import BST
from TreeNode import TreeNode

tree = TreeNode(1,
                TreeNode(2,
                         TreeNode(4,
                                  TreeNode(7,None,None),
                                  None),
                         TreeNode(5, None, None)),
                TreeNode(3,
                         TreeNode(6,
                                  TreeNode(8, None, None),
                                  TreeNode(9, None, None)),
                         None))

print(BST.preOrder(tree))

我知道它必須與我做一些事情,在我的打印聲明中放入一些“自我”的內容,但是我很沮喪,目前我的大腦無法正常運行。 有任何想法嗎?

進行一些更改對我來說很好。

bst.py:

class TreeNode(object):

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

        self.item = data
        self.left = left
        self.right = right

    def __str__(self):
        return str(self.item)


#------------------------------------------------------------


class BST(object):

    #------------------------------------------------------------

    def __init__(self):
        self.root = None
        self.size = 0

    #------------------------------------------------------------

    def preOrder(self, tree):
        if tree is None:
            pass
        else:
            print(tree.item)
            self.preOrder(tree.left)
            self.preOrder(tree.right)

    def postOrder(self, root):
        if root is None:
            pass
        else:
            self.postOrder(root.left)
            self.postOrder(root.right)
            print(root.item)

    def inOrder(self, root):
        if root is None:
            pass
        else:
            self.inOrder(root.left)
            print(root.item)
            self.inOrder(root.right)

東西

from bst import BST
from bst import TreeNode

tree = TreeNode(1,
                TreeNode(2,
                         TreeNode(4,
                                  TreeNode(7,None,None),
                                  None),
                         TreeNode(5, None, None)),
                TreeNode(3,
                         TreeNode(6,
                                  TreeNode(8, None, None),
                                  TreeNode(9, None, None)),
                         None))

a = BST()

print(a.preOrder(tree))

輸出:

bob@squids:~/Desktop$ python something.py
1
2
4
7
5
3
6
8
9
None

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM