文章出處

題目描述
給定一個二叉樹和其中的一個結點,請找出中序遍歷順序的下一個結點并且返回。注意,樹中的結點不僅包含左右子結點,同時包含指向父結點的指針。

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

文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()