Computer >> 컴퓨터 >  >> 프로그램 작성 >> Python

Python에서 범위에 없는 모든 노드를 BST에서 제거하는 프로그램

<시간/>

낮음과 높음의 두 값인 BST가 있다고 가정하면 [낮음, 높음](포함) 사이가 아닌 모든 노드를 삭제해야 합니다.

따라서 입력이 다음과 같으면

Python에서 범위에 없는 모든 노드를 BST에서 제거하는 프로그램

낮음 =7 높음 =10이면 출력은 다음과 같습니다.

Python에서 범위에 없는 모든 노드를 BST에서 제거하는 프로그램

이 문제를 해결하기 위해 다음 단계를 따릅니다. −

  • solve() 함수를 정의합니다. 이것은 뿌리를 내릴 것입니다, 낮음, 높음
  • 루트가 null이면
    • 반환
  • 낮으면> 루트의 데이터, 그러면
    • 반환 해결(루트 오른쪽, 낮음, 높음)
  • 높은 <루트의 데이터이면
    • 해결 반환(루트 왼쪽, 낮음, 높음)
  • 루트 오른쪽 :=해결(루트 오른쪽, 낮음, 높음)
  • 루트 왼쪽 :=해결(루트 왼쪽, 낮음, 높음)
  • 루트 반환

이해를 돕기 위해 다음 구현을 살펴보겠습니다. −

class TreeNode:
   def __init__(self, data, left = None, right = None):
      self.data = data
      self.left = left
      self.right = right
def print_tree(root):
   if root is not None: print_tree(root.left)
      print(root.data, end = ', ') print_tree(root.right)
class Solution:
   def solve(self, root, low, high):
      if not root:
         return
      if low > root.data:
         return self.solve(root.right,low,high)
      if high < root.data:
         return self.solve(root.left,low,high)
         root.right = self.solve(root.right,low,high)
         root.left = self.solve(root.left,low,high)
      return root
ob = Solution()
root = TreeNode(5)
root.left = TreeNode(1)
root.right = TreeNode(9) root.right.left = TreeNode(7) root.right.right = TreeNode(10) root.right.left.left = TreeNode(6) root.right.left.right = TreeNode(8) low = 7
high = 10
ret = ob.solve(root, low, high) print_tree(ret)

입력

root = TreeNode(5)
root.left = TreeNode(1)
root.right = TreeNode(9)
root.right.left = TreeNode(7)
root.right.right = TreeNode(10)
root.right.left.left = TreeNode(6)
root.right.left.right = TreeNode(8)
low = 7
high = 10

출력

7, 8, 9, 10,