Python搜索树

Python搜索树 首页 / 数据结构入门教程 / Python搜索树

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

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

在B树中搜索值

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

链接:https://www.learnfk.comhttps://www.learnfk.com/python-data-structure/python-binary-search-tree.html

来源:LearnFk无涯教程网

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绘画核心技术与实战 -〔南柯〕

说透元宇宙 -〔方军〕

手把手带你写一门编程语言 -〔宫文学〕

打造爆款短视频 -〔周维〕

分布式金融架构课 -〔任杰〕

OAuth 2.0实战课 -〔王新栋〕

罗剑锋的C++实战笔记 -〔罗剑锋〕

邱岳的产品实战 -〔邱岳〕

好记忆不如烂笔头。留下您的足迹吧 :)