LCR 045.找树左下角的值
md
给定一个二叉树的 根节点 root,请找出该二叉树的 最底层 最左边 节点的值。
假设二叉树中至少有一个节点。
示例 1:
输入: root = [2,1,3]
输出: 1
示例 2:
输入: [1,2,3,4,null,5,6,null,null,7]
输出: 7
提示:
二叉树的节点个数的范围是 [1,104]
-231 <= Node.val <= 231 - 1就是层序遍历, 每一层的的最左边的那个节点就是要找的节点 与本题类似的还有 LCR 046.二叉树的右视图
go
/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func findBottomLeftValue(root *TreeNode) int {
// 还是层序遍历, 他就是最底下那层的第一个节点
q := []*TreeNode{root}
res := 0
for len(q) > 0 {
n := len(q)
for i := 0; i < n; i++ {
node := q[0]
q = q[1:]
if i == 0 {
res = node.Val
}
if node.Left != nil {
q = append(q, node.Left)
}
if node.Right != nil {
q = append(q, node.Right)
}
}
}
return res
}