二叉树的后继节点

简介: 二叉树的后继节点

Successor node

问题

求二叉树里一个节点的后继节点

思路

判断情况:

节点有右子树:找右子树的最左节点

节点没有右子树:往上查找,但节点不能为父节点的左子树

实现

class Node
{
    public:
    Node* left;
    Node* right;
    Node* parent;
    Node():left(nullptr),right(nullptr),parent(nullptr){}   
};
Node* GetSuccessorNode(Node* root,Node* cur)
{
    if(!cur) return cur;
    if(cur->right) return GetLeftestNode(cur->right);
    Node* parent = cur->parent;
    while(parent != nullptr && parent->left != cur)
    {
        cur = parent;
        parent = cur->parent;
    }
    return parent;
}
Node* GetLeftestNode(Node* root)
{
    while(root->left)
    {
        root = root->left;
    }
    return root;
}


目录
相关文章
【Leetcode -872.叶子相似的树 -993.二叉树的堂兄弟节点】
【Leetcode -872.叶子相似的树 -993.二叉树的堂兄弟节点】
44 0
|
7月前
|
算法 C++ 开发者
【C/C++ 数据结构 】二叉树基本性质:对于任何一颗二叉树T,若其终端结点为n0 ,那么度数为2的结点数为n2。则n0=n2+1...
【C/C++ 数据结构 】二叉树基本性质:对于任何一颗二叉树T,若其终端结点为n0 ,那么度数为2的结点数为n2。则n0=n2+1...
95 0
|
7月前
|
存储
二叉树详解(深度优先遍历、前序,中序,后序、广度优先遍历、二叉树所有节点的个数、叶节点的个数)
二叉树详解(深度优先遍历、前序,中序,后序、广度优先遍历、二叉树所有节点的个数、叶节点的个数)
|
6月前
【树 - 平衡二叉树(AVL)】F(n)=F(n-1)+F(n-2)+1 这个类似于一个递归的数列,1是根节点,F(n-1)是左子树的节点数量,F(n-2)是右子树的节点数量
【树 - 平衡二叉树(AVL)】F(n)=F(n-1)+F(n-2)+1 这个类似于一个递归的数列,1是根节点,F(n-1)是左子树的节点数量,F(n-2)是右子树的节点数量
剑指offer-7.二叉树的下一个节点
剑指offer-7.二叉树的下一个节点
43 1
|
数据安全/隐私保护
列出叶节点 (二叉树的建立和BFS)
列出叶节点 (二叉树的建立和BFS)
97 1
剑指offer 07. 二叉树的下一个节点
剑指offer 07. 二叉树的下一个节点
66 0
|
算法 JavaScript 开发者
寻找二叉树的下一个节点
寻找二叉树的下一个节点
寻找二叉树的下一个节点
|
算法 前端开发
二叉树的堂兄弟节点
🎈今天给大家带来的是算法练习,题目为二叉树的堂兄弟节点。
131 1