剑指offer-8二叉树的下一个节点

Muche Muche     2022-12-24     448

关键词:

剑指offer-8 二叉树的下一个节点

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

思路:

  1. 右侧有节点,直接打印
  2. 右侧没节点
    1. 此节点的父节点的左节点是自己,打印
    2. 此节点的父节点的右节点是自己,向上继续找,直到满足2.1

自己解答:

/*
public class TreeLinkNode 
    int val;
    TreeLinkNode left = null;
    TreeLinkNode right = null;
    TreeLinkNode next = null;

    TreeLinkNode(int val) 
        this.val = val;
    

*/
public class Solution 
    public TreeLinkNode GetNext(TreeLinkNode pNode)
    
        if(pNode == null) return null;
        TreeLinkNode next = null;
        if(pNode.right != null)
            TreeLinkNode pRight = pNode.right;            
            while(pRight.left != null)
                pRight = pRight.left;
            next = pRight;
        else if(pNode.next != null)
            TreeLinkNode curNode = pNode;
            TreeLinkNode pParrent = pNode.next;
            while(pParrent != null && pParrent.right == curNode)
                curNode = pParrent;
                pParrent = pParrent.next;
            
            next = pParrent;
        
        return next;        
    

犯的错误:

注意:

别人解答:

剑指offer第7题二叉树的下一个节点

【题目】给定一棵二叉树的其中一个节点,请找出中序遍历序列的下一个节点。注意:如果给定的节点是中序遍历序列的最后一个,则返回空节点;二叉树一定不为空,且给定的节点一定不是空节点;样例假定二叉树是:[2,1,3,null... 查看详情

剑指offer:二叉树的下一个节点(代码片段)

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。classTreeLinkNode:def__init__(self,x):self.val=xself.left=Noneself.right=Noneself.paren... 查看详情

剑指offer——06二叉树的下一个节点(代码片段)

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 题目的意思是,在一颗二叉树的中序遍历中,给出其中一个节... 查看详情

剑指offer二叉树的下一个结点

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 思路:1)如果一个节点有右子树,那么它的下一个结点就是... 查看详情

剑指offer(书):二叉树的下一个节点(代码片段)

题目:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。分析:若一个节点有右子树,那么他的下一个节点就是他右子树中的... 查看详情

剑指offer-二叉树的下一个节点(代码片段)

给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 ①节点右孩子存在,则设置一个指针从该节点的右孩子出发,一直沿着... 查看详情

剑指offer(57)二叉树的下一个节点(代码片段)

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 题目分析这题一定要画图,因为只有画图我们才能分清楚下一... 查看详情

剑指offer(python)------二叉树的下一个节点(代码片段)

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。这道题意即:给定一个节点,按照中序遍历(左根右)的方式求该... 查看详情

57剑指offer--二叉树的下一结点

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 解题思路:两种情况,若果一个结点有右子树,那么其下一个... 查看详情

《剑指offer——从中序遍历中找出二叉树的下一个结点》代码(代码片段)

从中序遍历中找出二叉树一个节点的下一个结点问题一、解析问题二、代码解析1.新建.cpp文件我们用如下C++代码从二叉树中找出一个节点的下一个节点(示例):问题//===========&... 查看详情

剑指offer-57.二叉树的下一个结点(c++/java)(代码片段)

题目:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。分析:二叉树的中序遍历是左根右,所以如果一个结点的右子树不为... 查看详情

剑指offer:二叉树的下一节点(代码片段)

题意描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。解题思路一、暴力解决分析Node可能在二叉树的所有位置,逐个进... 查看详情

剑指offer面试题8.二叉树的下一个结点

面试题8.二叉树的下一个结点NowCoder题目描述给定一棵二叉树和其中的一个结点,如何找出中序遍历顺序的下一个结点?树中的结点除了有两个分别指向左右子结点的指针以外,还有一个指向父结点的指针。Java实现略 查看详情

剑指offer---二叉树的下一个结点

/*structTreeLinkNode{intval;structTreeLinkNode*left;structTreeLinkNode*right;structTreeLinkNode*next;TreeLinkNode(intx):val(x),left(NULL),right(NULL),next(NULL){}};*/classSolution{public:TreeLinkNode* 查看详情

[剑指offer]面试题8:二叉树的下一个节点(代码片段)

题目描述 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 解题思路 1.找到所有的可能情况并归纳,写的代码需... 查看详情

剑指offer8二叉树中序遍历的下一个节点(代码片段)

题目给定一个二叉树和其中一个节点,找出中序遍历的下一个节点。注意:树的节点中除了有指向左右节点的指针,还有指向父节点的指针。思路(1)若该节点Node有右子树,则下一个节点就是右子树中的最左节点,就是在右节... 查看详情

剑指offer-二叉树的下一个结点(代码片段)

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 若结点存在右孩子,则右孩子的最坐下结点为中序遍历下一个... 查看详情

[剑指offer]二叉树的下一个结点(代码片段)

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。   题目链接:https://www.nowcoder.com/practice/9023a0c988684a539603... 查看详情