美文网首页
2019-09-11[剑指offer-]二叉树的下一个节点

2019-09-11[剑指offer-]二叉树的下一个节点

作者: Coding破耳 | 来源:发表于2019-11-15 22:24 被阅读0次

题目描述

给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。

/*
struct TreeLinkNode {
    int val;
    struct TreeLinkNode *left;
    struct TreeLinkNode *right;
    struct TreeLinkNode *next;
    TreeLinkNode(int x) :val(x), left(NULL), right(NULL), next(NULL) {
        
    }
};
*/
class Solution {
public:
    TreeLinkNode* GetNext(TreeLinkNode* pNode)
    {
        if(pNode == NULL)
        {
            return NULL;
        }
        
        if(pNode->right)
        {
            TreeLinkNode* tmpNode = pNode->right;
            while(tmpNode->left)
            {
                tmpNode = tmpNode->left;
            }
            return tmpNode;
        }
        else
        {
            TreeLinkNode* pHead = pNode->next;
            if(pHead)
            {
                if(pHead->left == pNode)
                {
                    return pHead;
                }
                else
                {
                    if(pHead->next && pHead->next->left == pHead)
                    {
                        return pHead->next;
                    }
                }
            }
        }
        
        return NULL;
    }
};

相关文章

网友评论

      本文标题:2019-09-11[剑指offer-]二叉树的下一个节点

      本文链接:https://www.haomeiwen.com/subject/gmjwyctx.html