首页 > 其他 > 详细

剑指 Offer 32 - I. 从上到下打印二叉树

时间:2021-01-05 18:51:37      阅读:22      评论:0      收藏:0      [点我收藏+]

剑指 Offer 32 - I. 从上到下打印二叉树

地址:剑指 Offer 32 - I. 从上到下打印二叉树

从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。

例如:
给定二叉树: [3,9,20,null,null,15,7],

3

/
9 20
/
15 7
返回:

[3,9,20,15,7]

提示:

节点总数 <= 1000


/**
 * Definition for a binary tree node.
 * type TreeNode struct {
 *     Val int
 *     Left *TreeNode
 *     Right *TreeNode
 * }
 */
func levelOrder(root *TreeNode) []int {
    res := make([]int, 0)
    if root == nil {
        return res
    }

    queue := make([]*TreeNode, 0)
    queue = append(queue, root)
    for len(queue) > 0 {
        res = append(res, queue[0].Val)
        if queue[0].Left != nil {
            queue = append(queue, queue[0].Left)
        }
        if queue[0].Right != nil {
            queue = append(queue, queue[0].Right)
        }
        queue = queue[1:]
    }
    return res
}

剑指 Offer 32 - I. 从上到下打印二叉树

原文:https://www.cnblogs.com/ganshuoos/p/14236396.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!