Leetcode 230 Kth Smallest Element in a BST

image
Input: root = [3,1,4,null,2], k = 1 Output: 1
image
Input: root = [5,3,6,2,4,null,null,1], k = 3 Output: 3
  • Soruda bize ikili arama ağacının kökü ve k sayısı veriliyor.Bu ağaçtaki küçükten büyüğe sıralarsak k sırasındaki sayıyı bulmamız isteniyor.
  • İkili arama ağacı yapısında hep sol köke giderek en küçük sayıyı buluruz.Bu ilerleme sırasında bulduğumuz sayıları stack içine koyarız.
  • Daha sonra stackten çıkardığımız sayıların sağ köklerini de kontrol ederek sıralamamızı oluştururuz.
# 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 kthSmallest(self, root: Optional[TreeNode], k: int) -> int:
        n = 0
        stack = []
        cur = root
        
        while cur or stack:
            while cur:
                stack.append(cur)
                cur = cur.left
                
            cur = stack.pop()
            n +=1
            if n==k:
                return cur.val
            cur = cur.right