二叉树层次遍历c语言_LeetCode-102 二叉树的层次遍历

题目:给定一个二叉树,返回其按层次遍历的节点值。 (即逐层地,从左到右访问所有节点)。

fdfbab5034517d91fac2ac02d56d4007.png

解法一:迭代法

  • 用两个数组,分别表示当前遍历层temp、存储当前层的下一层temp2;
  • 再用两个数组,分别存储当前层的值res1、总的各层值res2。

代码如下:

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def levelOrder(self, root: TreeNode) -> List[List[int]]:
        if not root:return []
        res = []

        temp = []
        temp.append(root)

        while temp:
            res2 = []
            temp2 = []
            for cur in temp:
                res2.append(cur.val)
                if cur.left:
                    temp2.append(cur.left)
                if cur.right:
                    temp2.append(cur.right)
            res.append(res2)
            temp = temp2
        return res

执行结果:通过显示详情
执行用时 :36 ms, 在所有 python3 提交中击败了96.10%的用户
内存消耗 :12.8 MB, 在所有 python3 提交中击败了99.73%的用户

原本想用队列,可搞不清楚python3中的deque和queue的用法和区别。

在 Python 中如果使用 Queue 结构,但因为它是为多线程之间安全交换而设计的,所以使用了锁,会导致性能不佳。因此在 Python 中可以使用 deque 的 append() 和 popleft() 函数来快速实现队列的功能。

解法二:递归法

考虑递归时,卡在了如何区分第几层。此时只需在传参时,将当前节点所处的层数作为第二个参数即可。

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def levelOrder(self, root: TreeNode) -> List[List[int]]:
        res = []
        if not root:return res

        def countlevel(node, level):
            if len(res) == level:
                res.append([])
            
            res[level].append(node.val)

            if node.left:
                countlevel(node.left, level+1)
            if node.right:
                countlevel(node.right, level+1)
        
        countlevel(root, 0)
        return res

执行结果:通过显示详情
执行用时 :32 ms, 在所有 python3 提交中击败了98.90%的用户
内存消耗 :13.2 MB, 在所有 python3 提交中击败了94.93%的用户

官解参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值