Python搜索树

/ / Python搜索树

二进制搜索树(BST)是一棵树,其中所有节点都遵循下述属性- 节点的左子树的键小于或等于其父节点的键,右子树的键大于其父节点的键。 因此,BST将其所有子树分为两个部分:左子树和右子树,可以定义为–

left_subtree (keys)    node (key)    right_subtree (keys)

在B树中搜索值

在树中搜索值涉及将输入值与退出节点值进行比较,在这里,无涯教程也从左到右遍历节点,最后与父节点遍历,如果搜索到的值与任何退出值都不匹配,则返回“Not Found”消息,否则返回找到的消息。

class Node:

    def __init__(self, data):

        self.left=None
        self.right=None
        self.data=data

# 插入方法创建节点
    def insert(self, data):

        if self.data:
            if data < self.data:
                if self.left is None:
                    self.left=Node(data)
                else:
                    self.left.insert(data)
            elif data > self.data:
                if self.right is None:
                    self.right=Node(data)
                else:
                    self.right.insert(data)
        else:
            self.data=data
# findval 方法将值与节点进行比较
    def findval(self, lkpval):
        if lkpval < self.data:
            if self.left is None:
                return str(lkpval)+" Not Found"
            return self.left.findval(lkpval)
        elif lkpval > self.data:
            if self.right is None:
                return str(lkpval)+" Not Found"
            return self.right.findval(lkpval)
        else:
            print(str(self.data) + ' is found')
# 打印树
    def PrintTree(self):
        if self.left:
            self.left.PrintTree()
        print( self.data),
        if self.right:
            self.right.PrintTree()


root=Node(12)
root.insert(6)
root.insert(14)
root.insert(3)
print(root.findval(7))
print(root.findval(14))

执行以上代码后,将产生以下输出-

无涯教程网

7 Not Found
14 is found

祝学习愉快! (发现内容有误?请选中要编辑的内容 -> 右键 -> 修改 -> 提交!帮助我们改进教程质量)

精选教程推荐

👇 以下精选教程可能对您有帮助,拓展您的技术视野

AI Excel从入门到实战 -〔张海航〕

超级访谈:对话张雪峰 -〔张雪峰〕

图解 Google V8 -〔李兵〕

摄影入门课 -〔小麥〕

小马哥讲Spring核心编程思想 -〔小马哥〕

分布式技术原理与算法解析 -〔聂鹏程〕

Spring Boot与Kubernetes云原生微服务实践 -〔杨波〕

Go语言从入门到实战 -〔蔡超〕

10x程序员工作法 -〔郑晔〕

📝 好记忆不如烂笔头,留下您的学习笔记吧!

暂无学习笔记,成为第一个分享的人吧!

您的笔记将帮助成千上万的学习者