题解 | #二叉树的下一个结点#

二叉树的下一个结点

https://www.nowcoder.com/practice/9023a0c988684a53960365b889ceaf5e?tpId=13&tqId=23451&ru=/exam/oj/ta&qru=/ta/coding-interviews/question-ranking&sourceUrl=%2Fexam%2Foj%2Fta%3Fpage%3D1%26tpId%3D13%26type%3D13

# -*- coding:utf-8 -*-
# class TreeLinkNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#         self.next = None
class Solution:
    def __init__(self):
        self.nodes = []

    def GetNext(self, pNode):
        # write code here
        # print(pNode)
        # print()
		'''
		找到树的根然后利用树的根找到中序遍历树的所有节点,按中序遍历的顺序添加到nodes列表中
		'''
        root = pNode
        while root.next:
            root = root.next

        self.MiddleTravel(root)

        for i in range(len(self.nodes)-1):
            if self.nodes[i] == pNode:
                return self.nodes[i+1]
	   #如果没有在nodes列表中找到和pNode相同的节点,返回None
        return None

    def MiddleTravel(self, root):
        if not root:
            return 
        self.MiddleTravel(root.left)
        self.nodes.append(root)
        self.MiddleTravel(root.right)

全部评论

相关推荐

头像
不愿透露姓名的神秘牛友
04-08 00:50
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务