4.6 Write an algorithm to find the'next'node (i.e., in-order successor) of a given node in a binary search tree. You may assume that each node has a link to its parent.

这道题实际上考察的是一种叫线索二叉树的数据结构,而构造这种树的方法称之为Morris遍历法,在我之前的博客Binary Tree Inorder Traversal 二叉树的中序遍历有详细的介绍,然而并没什么卵用,因为这道题给了个条件,说每个节点都可以链接到其父节点,这样一来就大大的简化了问题。首先我们知道二叉搜索树的性质的左<=根<右,那么其中序遍历就是一个递增的有序数列,那么我们如何找到一个节点的下一个节点呢。思路是这样的,首先我们判断输入节点是否为空,若为空直接返回NULL,若不为空,在看其右子节点是否存在,存在的话找到右子树中最左的左子节点返回。如果右子节点不存在,则说明该点的子树全遍历完了,就要往其父节点上去找未被遍历完全的节点,参见代码如下:

class Solution {
public:
TreeNode* inorderSucc(TreeNode *n) {
if (!n) return NULL;
if (n->right) {
TreeNode *p = n->right;
while (p->left) p = p->left;
return p;
} else {
TreeNode *q = n, *x = q->parent;
while (x && x->left != q) {
q = x;
x = x->parent;
}
return x;
}
}
};

最新文章

  1. linux开启FTP以及添加用户配置权限,只允许访问自身目录,不能跳转根目录
  2. JSP表单提交中文乱码解决方案
  3. js的预解析和代码执行相关规则
  4. 【JavaScript】停不下来的前端,自动化流程
  5. 管理口令(P):[INS-30001] ADMIN口令为空之Oracle安装
  6. 十六、mysql 分区之 简单sql优化2
  7. C# - ref &amp; out
  8. (转)Ajax的原理和应用
  9. GC选择之CMS 并发标记清除
  10. Comparators.sort (转载)
  11. 【Qt编程】基于Qt的词典开发系列&lt;三&gt;--开始菜单的设计
  12. Java:配置环境(Mac)——MySQL
  13. Lua“控制”C
  14. CSS3_盒子背景
  15. 微信小程序笑话小程序实践开发学习
  16. nasm学习资料
  17. 实时监听input输入的变化(兼容主流浏览器)【转】
  18. 解析3D标签云,其实很简单
  19. fastjson 处理 double 的精度问题
  20. C++的虚函数试题,常考!!

热门文章

  1. CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)
  2. Effective Java 56 Adhere to generally accepted naming conventions
  3. JSON 格式介绍
  4. 【转】App开发者必备的运营、原型、UI设计工具整理
  5. linux下开启SSH,并且允许root用户远程登录,允许无密码登录
  6. TCP连接与关闭
  7. [转]asp.net的ajax以及json
  8. [转]excel set drop-down values based on vlookup
  9. [转]用NPOI操作EXCEL--数据有效性
  10. Legendre polynomials