59.二叉树的下一个节点(代码片段)

yjxyy yjxyy     2022-12-15     253

关键词:

题目描述:

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

思路分析:

??二叉树的下一个节点,一共有以下情况:

??1.二叉树为空,返回空

??2.节点的右孩子存在,则设置一个指针从右孩子出发,一直沿着左子节点的指针找到的叶子节点即为下一个节点。

??3.节点不是根节点,如果节点时父节点的左孩子,那么父节点就是下一个节点,否则继续向上遍历其父节点的父节点,重复之前的判断,返回结果。

代码:

/*
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;
        if(pNode.right!=null)    //右孩子不为空,从右孩子开始,沿着左指针遍历到叶子节点,即为下一个节点
            pNode=pNode.right;
            while(pNode.left!=null)
                pNode=pNode.left;
            
            return pNode;
        
        while(pNode.next!=null)    //pNode不为根节点
            TreeLinkNode parentNode=pNode.next;
            if(parentNode.left==pNode) //如果当前节点时父节点的左孩子,那么下一个节点就是父节点。
                return parentNode;
            pNode=pNode.next;
        
        return null;
    

二叉树的下一个节点(代码片段)

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。思路首先知道中序遍历的规则是:左根右,然后作图 1.若当前... 查看详情

面试题:二叉树的下一个节点(代码片段)

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

二叉树的下一个结点(代码片段)

...语言2秒空间限制:C/C++32M,其他语言64M题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。思路:中序遍历:左中右,... 查看详情

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

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

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

一.题目给定一棵二叉树和其中的一个结点,如何找出中序遍历顺序的下一个结点?树中的结点除了有两个分别指向左右子结点的指针以外,还有一个指向父结点的指针。二.思路分析题目之后,我们发现,待处理节点只存在三种... 查看详情

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

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

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

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

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

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

经典算法题-基础-寻找二叉树的下一个节点(代码片段)

...且是父节点的右孩子相关代码问题描述题目描述给定一个二叉树和其中的一个结点,请找出中序遍历中的下一个结点并且返回要求时间限制:1秒空间限制:32768K方法原型publicTreeNodegetNext(TreeNodetreeNode)publicclassTreeNodeintval;TreeNode 查看详情

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

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

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

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

57.二叉树的下一个结点(python)(代码片段)

思路如果该节点有右节点,那么它的下一个结点就是其右子树的最左节点否则,如果他是父节点的左节点,则返回他的父节点,否则往上找,直到他的某个父节点a是a父节点的左节点,返回a的父节点。1classSolution:2defGetNext(self,pNod... 查看详情

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

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

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

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

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

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

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

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

leetcode二叉树专项填充每个节点的下一个右侧节点指针(116)(代码片段)

...先遍历)2.1分析2.2解答2.3复杂度1.题目给定一棵完美二叉树,即该二叉树的所有叶子结点都在同一层且每一个父结点都有两个子结点,二叉树的结点定义如下:structNodeintval;Node*left;Node*right;Node*next;请 查看详情

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

剑指offer-8二叉树的下一个节点题目:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。思路:右侧有节点,直接打印右侧没... 查看详情