18-树-填充每个节点的下一个右侧节点指针

这是树的第18篇算法,力扣链接

给定一个 完美二叉树,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:

复制代码
struct Node {
  int val;
  Node *left;
  Node *right;
  Node *next;
}

填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL

初始状态下,所有 next 指针都被设置为 NULL

示例 1:

复制代码
输入:root = [1,2,3,4,5,6,7]
输出:[1,#,2,3,#,4,5,6,7,#]
解释:给定二叉树如图 A 所示,你的函数应该填充它的每个 next 指针,以指向其下一个右侧节点,如图 B 所示。序列化的输出按层序遍历排列,同一层节点由 next 指针连接,'#' 标志着每一层的结束。

这道题看起来复杂,其实可以用广度/层级遍历解决。无非是一层一层的遍历所有的节点,然后将前一个节点与后一个节点绑定。

Go 复制代码
func connect(root *Node) *Node {
	if root == nil {
		return nil
	}
	queue := []*Node{root}
	for len(queue) > 0 {
		var prev *Node
		for _, node := range queue {
			if prev != nil {
				prev.Next = node
			}
			if node.Left != nil {
				queue = append(queue, node.Left)
			}
			if node.Right != nil {
				queue = append(queue, node.Right)
			}
			prev = node
			queue = queue[1:]
		}
	}
	return root
}

第二个做法比较特别,一只选取最左节点,将其子节点的左节点连上右节点。

Go 复制代码
func connect(root *Node) *Node {
	if root == nil {
		return nil
	}
	leftMost := root
	for leftMost.Left != nil {
		head := leftMost
		for head != nil {
			head.Left.Next = head.Right
			if head.Next != nil {
				head.Right.Next = head.Next.Left
			}
			head = head.Next
		}
		leftMost = leftMost.Left
	}
	return root
}
相关推荐
舟舟亢亢3 小时前
算法总结——二叉树【hot100】(上)
java·开发语言·算法
weixin_477271694 小时前
根象:树根。基石。基于马王堆帛书《周易》原文及甲骨文还原周朝生活活动现象(《函谷门》原创)
算法·图搜索算法
普通网友4 小时前
多协议网络库设计
开发语言·c++·算法
努力努力再努力wz4 小时前
【Linux网络系列】:TCP 的秩序与策略:揭秘传输层如何从不可靠的网络中构建绝对可靠的通信信道
java·linux·开发语言·数据结构·c++·python·算法
daxi1505 小时前
C语言从入门到进阶——第9讲:函数递归
c语言·开发语言·c++·算法·蓝桥杯
持续学习的程序员+16 小时前
强化学习Q-chunking算法
算法
Polaris北6 小时前
第二十七天打卡
开发语言·c++·算法
风吹乱了我的头发~7 小时前
Day30:2026年2月20日打卡
算法
blackicexs7 小时前
第五周第五天
算法
不吃橘子的橘猫7 小时前
《集成电路设计》复习资料2(设计基础与方法)
学习·算法·fpga开发·集成电路·仿真·半导体