python实现leetcode之99. 恢复二叉搜索树
2021-09-23 本文已影响0人
深圳都这么冷
解题思路
先中序遍历一下,将每个节点放入遍历队列中
再根据节点的值排序
然后zip遍历,其中有且仅有两个节点的值不想等,交换值即可
99. 恢复二叉搜索树
代码
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:
def recoverTree(self, root: TreeNode) -> None:
"""
Do not return anything, modify root in-place instead.
"""
queue = []
def in_order(tree):
if not tree: return
in_order(tree.left)
queue.append(tree)
in_order(tree.right)
in_order(root)
new_queue = sorted(queue, key=lambda n: n.val)
for x, y in zip(queue, new_queue):
if x != y:
x.val, y.val = y.val, x.val
break
data:image/s3,"s3://crabby-images/ec287/ec287a224250c3d96154dd980e9ba8ba6f3d6dba" alt=""