题目:
思路:
题目意思可以理解为每一层 从左到右连接起来!
如果使用前序遍历如:
Node connect(Node root) {
if (root == null || root.left == null) {
return root;
}
root.left.next = root.right;
connect(root.left);
connect(root.right);
return root;
}
则只会连接同一个父节点下的左右子节点,而跨父节点的5、6节点就不能连接了!
二叉树的问题难点在于,如何把题目的要求细化成每个节点需要做的事情
树相关的题目,先搞清楚要当前root做什么?然后根据方法递归调用方法,让子节点做相同的事情。
那么,此题可以增加参数 !一个节点做不到,我们就给他安排两个节点,将每一层二叉树节点连接起来可以细化成: 将每两个相邻节点都连接起来即可:
递归三部曲:
- 参数为两个root,不需要返回值
- 终止条件即子节点为null
- 连接当前两个参数节点的下一层中相邻的节点,前序遍历和后序遍历都可以 !!!
class Solution {
public Node connect(Node root) {
//一个参数不行传俩
if(root==null){
return null;
}
con(root.left,root.right);
return root;
}
private void con(Node r1,Node r2){
if(r1==null || r2==null){ // 注意题目是完美二叉树,但写成|| 保险一点
return ; // 递归出口
}
// 前序遍历 !
r1.next=r2;
// 同一个父节点的左右子节点
con(r1.left,r1.right);
con(r2.left,r2.right);
// 跨越父节点的两个子节点
con(r1.right,r2.left);
}
}