7.二叉树的下一个节点

二叉树的下一个节点

1. 题目描述

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

2.思路

1.如果该节点有右子树,则下一个节点为左子树的最左节点
2.如果该节点没有右子树:
(1)如果该节点是其父节点的右子节点,则向上寻找是父节点左子节点的节点,下一个节点是找到的节点 的父节点
(2)如果该节点是其父节点的左子节点,则下一个节点是其父节点。

3.代码

/*
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 == nullptr)
            return nullptr;
        
        TreeLinkNode* pNext = nullptr;
        //如果当前节点是右节点,且右节点有左子节点
        if(pNode->right != nullptr){
            TreeLinkNode* pRight = pNode->right;
            while(pRight->left != nullptr){
                pRight = pRight->left;
            }
            pNext = pRight;
        }
        else if(pNode->next != nullptr){//如果没有右子树,并且他还是父节点的右子节点,则向父节点遍历
            TreeLinkNode* parentNode = pNode->next;
            TreeLinkNode* currentNode = pNode;
            while(parentNode != nullptr && currentNode == parentNode->right){
                currentNode = parentNode;
                parentNode = parentNode->next;
            }
            pNext = parentNode;
        }
        return pNext;
    }
};
发布了71 篇原创文章 · 获赞 0 · 访问量 803

猜你喜欢

转载自blog.csdn.net/jiangdongxiaobawang/article/details/103916812