面试题 17.12. BiNode
https://leetcode-cn.com/problems/binode-lcci/
题目描述
前置知识
二叉查找树
递归
公司
暂无
思路
实际上这就是一个考察二叉树遍历 + 二叉搜索(查找)树性质的题目。这类题目特别需要注意的是指针操作,这一点和链表反转系列题目是一样的。
首先我们要知道一个性质: 对于一个二叉查找树来说,其中序遍历结果是一个有序数组。 而题目要求你输出的恰好就是有序数组(虽然没有明说, 不过从测试用例也可以看出)。
因此一个思路就是中序遍历, 边遍历边改变指针即可。 这里有两个注意点:
指针操作小心互相引用,导致死循环。
你需要返回的是最左下角的节点,而不是题目给的 root。
对于第一个问题, 其实只要注意操作指针的顺序,以及在必要的时候重置指针即可。
对于第二个问题,我用了一个黑科技,让代码看起来简洁又高效。如果不懂的话, 你也可以换个朴素的写法。
理解了上面的内容的话, 那让我们进入正题。
其中绿色是我们要增加的连线,而黑色是是原本的连线。
我们再来看一个复杂一点的:
实际上,不管多么复杂。 我们只需要进行一次中序遍历,同时记录前驱节点。然后修改前驱节点和当前节点的指针即可,整个过程就好像是链表反转。
核心代码(假设 pre 我们已经正确计算出了):
剩下的就是如何计算 pre,这个也不难,直接看代码:
问题得以解决。
这里还有最后一个问题就是返回值,题目要返回的实际上是最左下角的值。如何取到最左下角的节点呢?我们来看下核心代码你就懂了,代码比较简单。
关键点
指针操作
返回值的处理
代码
复杂度分析
时间复杂度:$O(N)$,其中 N 为树的节点总数。
空间复杂度:$O(h)$,其中 h 为树的高度。
相关题目
大家对此有何看法,欢迎给我留言,我有时间都会一一查看回答。更多算法套路可以访问我的 LeetCode 题解仓库:https://github.com/azl397985856/leetcode 。 目前已经 37K star 啦。 大家也可以关注我的公众号《力扣加加》带你啃下算法这块硬骨头。
最后更新于