【广度优先搜索】513.找树左下角的值

DayNightStudy

共 1485字,需浏览 3分钟

 ·

2021-01-30 23:10

【广度优先搜索】513.找树左下角的值


给定一个二叉树,在树的最后一行找到最左边的值。


示例 1:


输入:


    2

   / \

  1   3


输出:

1

 


示例 2:


输入:


        1

       / \

      2   3

     /   / \

    4   5   6

       /

      7


输出:

7



题目解析

找到 树 左下角的值,需要做的操作:

  1. 首先需要找到 每一层最左边的值;

  2. 从 这些值中找到 最 下层的值

题目解答

方法:层次遍历的 非递归方法

思路:

  1.   利用 层遍历的 非递归方法 遍历 每一层

  2. 保存每一层 的 最左边一个元素;

  3. 最后取最后一个即为 答案

代码展示

# Definition for a binary tree node.# class TreeNode:#     def __init__(self, val=0, left=None, right=None):#         self.val = val#         self.left = left#         self.right = rightclass Solution:    def findBottomLeftValue(self, root: TreeNode) -> int:        '''            方法:队列迭代 (层次遍历非递归)        '''        # step 1:判空        res = -1        if not root:            return res         # step 2: 初始化队列        queue = collections.deque()        queue.append(root)        # step 3:层次遍历 非递归法        while queue:            # step 4:每一层做遍历            for i in range(len(queue)):                node = queue.popleft()                #  step 5:每一层 第一个元素                if i==0:                    res = node.val                # step 6:root 的 左子树 入队                if node.left:                    queue.append(node.left)                # step 7:root 的 右子树 入队                if node.right:                    queue.append(node.right)             return res
复杂度计算
  •  时间复杂度:O(N),其中 N 是二叉树的节点数。二叉树的所有节点有且只会被访问一次,因此时间复杂度为 O(N)。

  • -空间复杂度:O(N),当树为平衡二叉树时,最多有N/2个树节点入队,使用 O(N) 大小的额外空间

运行结果





浏览 22
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报