剑指offer系列之五十七:二叉树的下一个节点
来源:互联网 发布:excel数据导入系统 编辑:程序博客网 时间:2024/05/21 09:16
题目描述
给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。
根据中序遍历的特点,要找到一个节点的下一个节点无非就是三种情况:1、有右子树,这时只需要把其右孩子作为下一个遍历的(并不是要找的)节点,然后沿着该节点的左子树(如果有的话)出发,直到遇到叶子节点,那么该叶子节点就是其下一个要找的节点;2、没有右子树,则判断该节点是否是其父节点的左孩子,如果是则其下一个要找的节点是其父节点;3、如果不是其父节点的左孩子,则把其父节点作为下一个遍历的节点,向上回溯,直到找到父节点没有父节点并且父节点是父节点的父节点的左孩子为止。综合这三种情况就可以找到二叉树中任意一个节点的下一个节点。下面是具体的实现代码(已被牛客AC):
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) { TreeLinkNode curNode = null; //第一步:判断是否有右孩子 if(pNode.right != null){ curNode = pNode.right; while(curNode.left != null) curNode = curNode.left; return curNode; } //第二步:判断是否是其父节点的左孩子 if(pNode.next == null) return null; if(pNode == pNode.next.left){ return pNode.next; } //第三步:向上找其父节点,直到父节点是其父节点的父节点的左孩子 curNode = pNode.next; while(curNode.next != null){ if(curNode == curNode.next.left){ return curNode.next; } //继续向上找父节点 curNode = curNode.next; } return null; }}
0 0
- 剑指offer系列之五十七:二叉树的下一个节点
- 剑指offer(五十七)之二叉树的下一个结点
- 剑指offer系列之56:二叉树的下一个节点
- 剑指offer之二叉树的下一个节点
- 剑指Offer--二叉树的下一个节点
- 《剑指offer》二叉树的下一个节点
- 剑指offer-二叉树的下一个节点
- 剑指offer--二叉树的下一个节点
- 剑指offer-二叉树的下一个节点
- 【剑指offer】二叉树的下一个节点
- 剑指offer --- 二叉树的下一个节点
- 剑指offer 58 - 二叉树的下一个节点
- 剑指offer(60):二叉树的下一个节点
- 剑指offer——二叉树的下一个节点
- 剑指Offer面试题58:二叉树的下一个节点
- 13.剑指offer-二叉树的下一个节点
- 剑指offer 第八题 二叉树的下一个节点
- 剑指offer——二叉树的下一个节点___
- Mysql分库分表方案
- Android onMeasure and onLayout
- 关于ThinkPHP中$this->redirect的疑问。
- android bitmap compress(图片压缩)
- perl DBI mysql包安装详解
- 剑指offer系列之五十七:二叉树的下一个节点
- 实现统计每个栏目下的文章总数的调用
- RPG类型游戏—2
- SOAP
- 使用AFN出现的问题以及解决方法
- SourceTree版本管理工具以及冲突的解决方式
- 无法启动mysql服务错误 1067: 进程意外终止的解决方法大全
- iOS中对copy与mutableCopy的理解
- RAD Studio 10免费培训之LiveBindings表达式和实时数据绑定——讲义及范例程序下载