LeetCode 104. Maximum Depth of Binary Tree

개발공부를해보자·2025년 2월 8일

LeetCode

목록 보기
42/95

파이썬 알고리즘 인터뷰 문제 42번(리트코드 104번) Maximum Depth of Binary Tree
https://leetcode.com/problems/maximum-depth-of-binary-tree/

나의 풀이(Recursive)

# 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 = right
class Solution:
    def maxDepth(self, root: Optional[TreeNode]) -> int:
        if not root:
            return 0
        return max(self.maxDepth(root.left), self.maxDepth(root.right)) + 1

다른 풀이(BFS, Queue)

# 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 = right
class Solution:
    def maxDepth(self, root: Optional[TreeNode]) -> int:
        if not root:
            return 0
        queue = collections.deque([root])
        depth = 0

        while queue:
            depth += 1
            for _ in range(len(queue)):
                cur_root = queue.popleft()
                if cur_root.left:
                    queue.append(cur_root.left)
                if cur_root.right:
                    queue.append(cur_root.right)
        
        return depth
profile
개발 공부하는 30대 비전공자 직장인

0개의 댓글