欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个节点并返回。

程序员文章站 2024-02-21 14:14:51
...

给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个节点并返回。

给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个节点并返回。

/*
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)
    {
        TreeLinkNode *pcur=NULL;
        if(pNode->right!=NULL)
        {
            pcur=pNode->right;
            while(pcur->left!=NULL)
            {
                pcur=pcur->left;
            }
            return pcur;
        }
        if(pNode->next==NULL)
        {
            return NULL;
        }
        if(pNode==pNode->next->left)
        {
            return pNode->next;
        }
        pcur=pNode->next;
        while(pcur->next)
        {
            if(pcur==pcur->next->left)
            {
                return pcur->next;
            }
            pcur=pcur->next;
        }
        return NULL;
    }
};

 

相关标签: 每日一题