python数据结构二叉树中序查找算法
时间: 2023-06-30 18:24:30 浏览: 115
二叉树中序查找算法的基本思路是:从根节点开始,先递归遍历左子树,然后访问根节点,最后递归遍历右子树。具体实现如下:
```python
# 定义二叉树节点类
class TreeNode:
def __init__(self, val):
self.val = val
self.left = None
self.right = None
# 中序遍历二叉树
def inorderTraversal(root, res):
if root:
inorderTraversal(root.left, res)
res.append(root.val)
inorderTraversal(root.right, res)
# 查找二叉树中是否存在某个值
def searchBST(root, val):
if not root:
return False
if root.val == val:
return True
if val < root.val:
return searchBST(root.left, val)
else:
return searchBST(root.right, val)
```
其中,`inorderTraversal`函数实现了中序遍历二叉树,并将遍历结果存储在列表`res`中。`searchBST`函数则是基于中序遍历,通过递归实现了查找二叉树中是否存在某个值的功能。
阅读全文