1632
 правки
Изменения
м
 
rollbackEdits.php mass rollback
=== Поиск следующего и предыдущего элемента ===
====Реализация с использованием информации о родителе====
Если у узла есть правое поддерево, то следующий за ним элемент будет минимальным элементом в этом поддереве. Если у него нет правого поддерева, то нужно следовать вверх, пока не встретим узел, который является левым дочерним узлом своего родителя. Поиск предыдущего выполнятся аналогично. Если у узла есть левое поддерево, то следующий за ним предыдущий ему элемент будет максимальным элементом в этом поддереве. Если у него нет левого поддерева, то нужно следовать вверх, пока не встретим узел, который является правым дочерним узлом своего родителя. 
 '''Node''' next(x : '''Node'''):
    '''if''' x.right != ''null''
    '''return''' y
Обе операции выполняются за время <tex>O(h)</tex>.
====Реализация без использования информации о родителе====
Рассмотрим поиск следующего элемента для некоторого ключа <tex>x</tex>. Поиск будем начинать с корня дерева, храня текущий узел <tex>current</tex> и узел <tex>successor</tex>, последний посещенный узел, ключ которого больше <tex>x</tex>. <br>
          successor.right.parent = successor.parent
      '''else'''
        successor.parent.right = successor.leftright        '''if''' successor.left right != ''null''
          successor.right.parent = successor.parent
     '''if''' root.left != ''null''
       root = root.left
     '''else if''' root.right != ''null''
       root = root.right
     '''else'''
       root = root.right''null''
   '''return''' root
