[CareerCup] 4.6 Find Next Node in a BST 寻找二叉搜索树中下一个节点
2024-10-11 16:59:30
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;
}
}
};
最新文章
- linux开启FTP以及添加用户配置权限,只允许访问自身目录,不能跳转根目录
- JSP表单提交中文乱码解决方案
- js的预解析和代码执行相关规则
- 【JavaScript】停不下来的前端,自动化流程
- 管理口令(P):[INS-30001] ADMIN口令为空之Oracle安装
- 十六、mysql 分区之 简单sql优化2
- C# - ref &; out
- (转)Ajax的原理和应用
- GC选择之CMS 并发标记清除
- Comparators.sort (转载)
- 【Qt编程】基于Qt的词典开发系列<;三>;--开始菜单的设计
- Java:配置环境(Mac)——MySQL
- Lua“控制”C
- CSS3_盒子背景
- 微信小程序笑话小程序实践开发学习
- nasm学习资料
- 实时监听input输入的变化(兼容主流浏览器)【转】
- 解析3D标签云,其实很简单
- fastjson 处理 double 的精度问题
- C++的虚函数试题,常考!!
热门文章
- CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)
- Effective Java 56 Adhere to generally accepted naming conventions
- JSON 格式介绍
- 【转】App开发者必备的运营、原型、UI设计工具整理
- linux下开启SSH,并且允许root用户远程登录,允许无密码登录
- TCP连接与关闭
- [转]asp.net的ajax以及json
- [转]excel set drop-down values based on vlookup
- [转]用NPOI操作EXCEL--数据有效性
- Legendre polynomials