Как вы проверяете дерево двоичного поиска?

голоса
54

Я читал здесь упражнение в интервью, известный как проверка дерево двоичного поиска.

Как именно это работает? Что бы один искать в проверке дерево двоичного поиска? Я написал основное дерево поиска, но никогда не слышал об этой концепции.

Задан 01/02/2009 в 02:41
источник пользователем
На других языках...                            


30 ответов

голоса
13

«Проверка» бинарное дерево поиска означает , что вы убедитесь , что он действительно имеет все меньшие элементы на левой и больших элементов справа. По существу, это проверка , чтобы увидеть , если бинарное дерево бинарного поиск дерево.

Ответил 01/02/2009 в 02:44
источник пользователем

голоса
106

На самом деле это ошибка все же в одном из интервью.

LeftChild должны быть сверены (minLimitof узел, node.value)

RightChild должны быть сверены (node.value, MaxLimit узла)

IsValidBST(root,-infinity,infinity);

bool IsValidBST(BinaryNode node, int MIN, int MAX) 
{
     if(node == null)
         return true;
     if(node.element > MIN 
         && node.element < MAX
         && IsValidBST(node.left,MIN,node.element)
         && IsValidBST(node.right,node.element,MAX))
         return true;
     else 
         return false;
}

Другое решение (если пространство не является ограничивающим): Делает заказовМой обход дерева и хранить значение узлов в массиве. Если массив в отсортированном порядке, его действительный BST не иначе.

Ответил 17/04/2009 в 11:11
источник пользователем

голоса
5

Вот мое решение в Clojure:

(defstruct BST :val :left :right)

(defn in-order [bst]
  (when-let [{:keys [val, left, right]} bst]
    (lazy-seq
      (concat (in-order left) (list val) (in-order right)))))

(defn is-strictly-sorted? [col]
  (every?
    (fn `a b` (< a  b))
    (partition 2 1 col)))

(defn is-valid-BST [bst]
  (is-strictly-sorted? (in-order bst)))
Ответил 08/01/2010 в 08:30
источник пользователем

голоса
1

«Это лучше, чтобы определить инвариант первого Здесь инвариант. - любые две последовательные элементы BST в обходе упорядоченную должны быть в строго возрастающем порядке их появления (не могут быть равны, всегда возрастает в порядка обход). Таким образом, решение может быть только простой обход в заказ с запоминанием последней посещенной узлу и сравнение текущего узла против последнего посетил один к «<» (или «>») «.

Ответил 30/03/2010 в 09:07
источник пользователем

голоса
7

Итеративное решение с использованием симметричного обхода.

bool is_bst(Node *root) {
  if (!root)
    return true;

  std::stack<Node*> stack;
  bool started = false;
  Node *node = root;
  int prev_val;

  while(true) {
    if (node) {
      stack.push(node);
      node = node->left();
      continue;
    }
    if (stack.empty())
      break;
    node = stack.top();
    stack.pop();

    /* beginning of bst check */
    if(!started) {
      prev_val = node->val();
      started = true;
    } else {
      if (prev_val > node->val())
        return false;
      prev_val = node->val();
    }
    /* end of bst check */

    node = node->right();
  }
  return true;
}
Ответил 29/04/2011 в 22:35
источник пользователем

голоса
0

Рекурсивное решение:

isBinary(root)
    {
        if root == null 
          return true
       else if( root.left == NULL and root.right == NULL)
          return true
       else if(root.left == NULL)
           if(root.right.element > root.element)
               rerturn isBInary(root.right)
        else if (root.left.element < root.element)
              return isBinary(root.left)
        else
              return isBInary(root.left) and isBinary(root.right)

    }
Ответил 05/09/2011 в 16:36
источник пользователем

голоса
1
bool BinarySearchTree::validate() {
    int minVal = -1;
    int maxVal = -1;
    return ValidateImpl(root, minVal, maxVal);
}

bool BinarySearchTree::ValidateImpl(Node *currRoot, int &minVal, int &maxVal)
{
    int leftMin = -1;
    int leftMax = -1;
    int rightMin = -1;
    int rightMax = -1;

    if (currRoot == NULL) return true;

    if (currRoot->left) {
        if (currRoot->left->value < currRoot->value) {
            if (!ValidateImpl(currRoot->left, leftMin, leftMax)) return false;
            if (leftMax != currRoot->left->value && currRoot->value < leftMax)  return false;
        }
        else
            return false;
    } else {
        leftMin = leftMax = currRoot->value;
    }

    if (currRoot->right) {
        if (currRoot->right->value > currRoot->value) {
            if(!ValidateImpl(currRoot->right, rightMin, rightMax)) return false;
            if (rightMin != currRoot->right->value && currRoot->value > rightMin)  return false;
        }
        else return false;
    } else {
        rightMin = rightMax = currRoot->value;
    }

    minVal = leftMin < rightMin ? leftMin : rightMin;
    maxVal = leftMax > rightMax ? leftMax : rightMax;

    return true;
}
Ответил 13/02/2012 в 21:08
источник пользователем

голоса
0
// using inorder traverse based Impl
bool BinarySearchTree::validate() {
    int val = -1;
    return ValidateImpl(root, val);
}

// inorder traverse based Impl
bool BinarySearchTree::ValidateImpl(Node *currRoot, int &val) {
    if (currRoot == NULL) return true;

    if (currRoot->left) {
        if (currRoot->left->value > currRoot->value) return false;
        if(!ValidateImpl(currRoot->left, val)) return false;
    }

    if (val > currRoot->value) return false;
    val = currRoot->value;

    if (currRoot->right) {
        if (currRoot->right->value < currRoot->value) return false;
        if(!ValidateImpl(currRoot->right, val)) return false;
    }
    return true;
}
Ответил 14/02/2012 в 10:34
источник пользователем

голоса
-3
boolean isBST(Node root) {
    if (root == null) { return true; }
    return (isBST(root.left) && (isBST(root.right) && (root.left == null || root.left.data <= root.data) && (root.right == null || root.right.data > root.data));
}
Ответил 05/03/2012 в 23:45
источник пользователем

голоса
-1

Вот итерационное решение без использования дополнительного пространства.

Node{
     int value;
     Node right, left
  }

  public boolean ValidateBST(Node root){
    Node currNode = root;
    Node prevNode = null;
    Stack<Node> stack = new Stack<Node>();
    while(true){
        if(currNode != null){
            stack.push(currNode);
            currNode = currNode.left;
            continue;
        }
        if(stack.empty()){
            return;
        }
        currNode = stack.pop();
        if(prevNode != null){
            if(currNode.value < prevNode.value){
                return false;
            }
        }
        prevNode = currNode;
        currNode = currNode.right;
    }
}
Ответил 07/04/2012 в 02:07
источник пользователем

голоса
1
bool ValidateBST(Node *pCurrentNode, int nMin = INT_MIN, int nMax = INT_MAX)
{
    return
    (
        pCurrentNode == NULL
    )
    ||
    (
        (
            !pCurrentNode->pLeftNode ||
            (
                pCurrentNode->pLeftNode->value < pCurrentNode->value &&
                pCurrentNode->pLeftNode->value < nMax &&
                ValidateBST(pCurrentNode->pLeftNode, nMin, pCurrentNode->value)
            )
        )
        &&
        (
            !pCurrentNode->pRightNode ||
            (
                pCurrentNode->pRightNode->value > pCurrentNode->value &&
                pCurrentNode->pRightNode->value > nMin &&
                ValidateBST(pCurrentNode->pRightNode, pCurrentNode->value, nMax)
            )
        )
    );
}
Ответил 20/05/2012 в 03:33
источник пользователем

голоса
12

Лучшее решение, которое я нашел это O (п) и не использует дополнительное пространство. Это похоже на заказовМой обход, но вместо того, чтобы хранить его в массив, а затем проверить сортируются можем ли мы взять статическую переменные и проверить при обходе Симметричного ли отсортирован массив.

static struct node *prev = NULL;

bool isBST(struct node* root)
{
    // traverse the tree in inorder fashion and keep track of prev node
    if (root)
    {
        if (!isBST(root->left))
          return false;

        // Allows only distinct valued nodes
        if (prev != NULL && root->data <= prev->data)
          return false;

        prev = root;

        return isBST(root->right);
    }

    return true;
}
Ответил 06/06/2012 в 08:14
источник пользователем

голоса
0

Для того, чтобы выяснить, является ли данный BT является BST для любого типа данных, вам нужно пойти с ниже подходом. 1. вызов рекурсивной функции до конца листа узла с помощью симметричного обхода 2. Создайте свой минимум и максимум значения самостоятельно.

Элемент Дерево должно быть меньше / больше, чем оператор, определенный.

#define MIN (FirstVal, SecondVal) ((FirstVal) < (SecondVal)) ? (FirstVal):(SecondVal)
#define MAX (FirstVal, SecondVal) ((FirstVal) > (SecondVal)) ? (FirstVal):(SecondVal)

template <class T>
bool IsValidBST (treeNode &root)
{

   T min,  max;
   return IsValidBST (root, &min, &max);
}

template <class T>
bool IsValidBST (treeNode *root, T *MIN , T *MAX)
{
   T leftMin, leftMax, rightMin, rightMax;
   bool isValidBST;

   if (root->leftNode == NULL && root->rightNode == NULL)
   {
      *MIN = root->element;
      *MAX = root->element;
      return true;
   }

  isValidBST = IsValidBST (root->leftNode, &leftMin, &leftMax);

  if (isValidBST)
    isValidBST = IsValidBST (root->rightNode, &rightMin, &rightMax);

  if (isValidBST)
  {
     *MIN = MIN (leftMIN, rightMIN);
     *Max = MAX (rightMax, leftMax);
  }

  return isValidBST;
}
Ответил 13/06/2012 в 18:16
источник пользователем

голоса
0
bool isBST(struct node* root)
{
    static struct node *prev = NULL;
    // traverse the tree in inorder fashion and keep track of prev node
    if (root)
    {
        if (!isBST(root->left))
            return false;
        // Allows only distinct valued nodes
        if (prev != NULL && root->data <= prev->data)
            return false;
        prev = root;
        return isBST(root->right);
    }
    return true;
}

Работает отлично :)

Ответил 28/06/2012 в 11:24
источник пользователем

голоса
0

Рекурсия легко , но итерационный подход лучше, есть один итерационный вариант выше , но это слишком сложно , чем это необходимо. Вот лучшее решение в c++вы когда - нибудь найти в любом месте:

Этот алгоритм работает в O(N)время и нуждается в O(lgN)пространстве.

struct TreeNode
{
    int value;
    TreeNode* left;
    TreeNode* right;
};

bool isBST(TreeNode* root) {
    vector<TreeNode*> stack;
    TreeNode* prev = nullptr;
    while (root || stack.size()) {
        if (root) {
           stack.push_back(root);
           root = root->left;
        } else {
            if (prev && stack.back()->value <= prev->value)
                return false;
            prev = stack.back();
            root = prev->right;                    
            stack.pop_back();
        }
    }
    return true;
}
Ответил 04/11/2012 в 07:20
источник пользователем

голоса
0

Я написал решение использовать Симметричный Traversal BST и проверьте узлы в порядке возрастания в пространстве O(1)и во время O(n). TreeNode predecessorэто Prev узел. Я не уверен , что решение является правильным или нет. Поскольку заказовМои Traversal не может определить целое дерево.

public boolean isValidBST(TreeNode root, TreeNode predecessor) {
    boolean left = true, right = true;
    if (root.left != null) {
        left = isValidBST(root.left, predecessor);
    }
    if (!left)
        return false;

    if (predecessor.val > root.val)
        return false;

    predecessor.val = root.val;
    if (root.right != null) {
        right = isValidBST(root.right, predecessor);
    }

    if (!right)
        return false;

    return true;

}
Ответил 16/02/2013 в 03:25
источник пользователем

голоса
0

Ниже приводится реализация Java валидации BST, где мы путешествуем дерево упорядоченную DFS и возвращает ложь, если мы получим любое число, которое больше, чем последний номер.

static class BSTValidator {
  private boolean lastNumberInitialized = false;
  private int lastNumber = -1;

  boolean isValidBST(TreeNode node) {
    if (node.left != null && !isValidBST(node.left)) return false;

    // In-order visiting should never see number less than previous
    // in valid BST.
    if (lastNumberInitialized && (lastNumber > node.getData())) return false;
    if (!lastNumberInitialized) lastNumberInitialized = true;

    lastNumber = node.getData();

    if (node.right != null && !isValidBST(node.right)) return false;

    return true;
  }
}
Ответил 18/01/2014 в 06:58
источник пользователем

голоса
3

Так как в заказе обход из BST не является снижение последовательности, мы можем использовать это свойство , чтобы судить о том , бинарное дерево BST или нет. Использование Моррис обхода и поддержания preузла, мы могли бы получить решение в O (N) времени и O (1) космической сложности. Вот мой код

public boolean isValidBST(TreeNode root) {
    TreeNode pre = null, cur = root, tmp;
    while(cur != null) {
        if(cur.left == null) {
            if(pre != null && pre.val >= cur.val) 
                return false;
            pre = cur;
            cur = cur.right;
        }
        else {
            tmp = cur.left;
            while(tmp.right != null && tmp.right != cur)
                tmp = tmp.right;
            if(tmp.right == null) { // left child has not been visited
                tmp.right = cur;
                cur = cur.left;
            }
            else { // left child has been visited already
                tmp.right = null;
                if(pre != null && pre.val >= cur.val) 
                    return false;
                pre = cur;
                cur = cur.right;
            }
        }
    }
    return true;
}
Ответил 18/10/2014 в 20:13
источник пользователем

голоса
1

Я получил этот вопрос в телефонном интервью в последнее время и боролся с ней больше, чем я должен иметь. Я пытался следить за минимальные и максимальные в дочерних узлах, и я просто не мог обернуть мой мозг вокруг различных случаев под давлением интервью.

Подумав об этом, в то время как засыпание прошлой ночью, я понял, что это так просто, как отслеживание последнего узла вы посетили во время заказовМои обходе. В Java:

public <T extends Comparable<T>> boolean isBst(TreeNode<T> root) {
    return isBst(root, null);
}

private <T extends Comparable<T>> boolean isBst(TreeNode<T> node, TreeNode<T> prev) {
    if (node == null)
        return true;

    if (isBst(node.left, prev) && (prev == null || prev.compareTo(node) < 0 ))
        return isBst(node.right, node);

    return false;
}
Ответил 10/12/2014 в 05:21
источник пользователем

голоса
0

Итерационное решение.

private static boolean checkBst(bst node) {

    Stack<bst> s = new Stack<bst>();
    bst temp;
    while(node!=null){
        s.push(node);
        node=node.left;
    }
    while (!s.isEmpty()){
        node = s.pop();
        System.out.println(node.val);
        temp = node;
        if(node.right!=null){
            node = node.right;
            while(node!=null)
            {
                //Checking if the current value is lesser than the previous value and ancestor.
                if(node.val < temp.val)
                    return false;
                if(!s.isEmpty())
                    if(node.val>s.peek().val)
                        return false;
                s.push(node);
                if(node!=null)
                node=node.left;
            }
        }
    }
    return true;
}
Ответил 15/12/2014 в 14:44
источник пользователем

голоса
0

Это работает для дублей.

// time O(n), space O(logn)
// pseudocode
is-bst(node, min = int.min, max = int.max):
    if node == null:
        return true
    if node.value <= min || max < node.value:
        return false
    return is-bst(node.left, min, node.value)
        && is-bst(node.right, node.value, max)

Это работает даже int.minи int.maxзначения с использованием Nullableтипов.

// time O(n), space O(logn)
// pseudocode
is-bst(node, min = null, max = null):
    if node == null:
        return true
    if min != null && node.value <= min
        return false
    if max != null && max < node.value:
        return false
    return is-bst(node.left, min, node.value)
        && is-bst(node.right, node.value, max)
Ответил 25/03/2015 в 08:16
источник пользователем

голоса
0

Вдохновленный http://www.jiuzhang.com/solutions/validate-binary-search-tree/

Есть два основных решения: Обход и делим && властвуй.

public class validateBinarySearchTree {
    public boolean isValidBST(TreeNode root) {
        return isBSTTraversal(root) && isBSTDivideAndConquer(root);
    }

    // Solution 1: Traversal
    // The inorder sequence of a BST is a sorted ascending list
    private int lastValue = 0; // the init value of it doesn't matter.
    private boolean firstNode = true;
    public boolean isBSTTraversal(TreeNode root) {
        if (root == null) {
            return true;
        }

        if (!isValidBST(root.left)) {
            return false;
        }

        // firstNode is needed because of if firstNode is Integer.MIN_VALUE,
        // even if we set lastValue to Integer.MIN_VALUE, it will still return false
        if (!firstNode && lastValue >= root.val) {
            return false;
        }

        firstNode = false;
        lastValue = root.val;

        if (!isValidBST(root.right)) {
            return false;
        }

        return true;

    }

    // Solution 2: divide && conquer
    private class Result {
        int min;
        int max;
        boolean isBST;
        Result(int min, int max, boolean isBST) {
            this.min = min;
            this.max = max;
            this.isBST = isBST;
        }
    }

    public boolean isBSTDivideAndConquer(TreeNode root) {
        return isBSTHelper(root).isBST;
    }

    public Result isBSTHelper(TreeNode root) {
        // For leaf node's left or right
        if (root == null) {
            // we set min to Integer.MAX_VALUE and max to Integer.MIN_VALUE
            // because of in the previous level which is the leaf level,
            // we want to set the min or max to that leaf node's val (in the last return line)
            return new Result(Integer.MAX_VALUE, Integer.MIN_VALUE, true);
        }

        Result left = isBSTHelper(root.left);
        Result right = isBSTHelper(root.right);

        if (!left.isBST || !right.isBST) {
            return new Result(0,0, false);
        }

        // For non-leaf node
        if (root.left != null && left.max >= root.val
                && root.right != null && right.min <= root.val) {
            return new Result(0, 0, false);
        }

        return new Result(Math.min(left.min, root.val),
                Math.max(right.max, root.val), true);
    }
}
Ответил 07/10/2015 в 05:24
источник пользователем

голоса
-3

Вот мое рекурсивное решение написано в JavaScript

function isBST(tree) {
  if (tree === null) return true;

  if (tree.left != undefined && tree.left.value > tree.value) {
    return false;
  }

  if (tree.right != undefined && tree.right.value <= tree.value) {
    return false;
  }

  return isBST(tree.left) && isBST(tree.right);
}
Ответил 19/10/2015 в 03:29
источник пользователем

голоса
1

В Java и позволяя узлам с таким же значением в любом суб-дереве:

public boolean isValid(Node node) {
    return isValid(node, Integer.MIN_VALUE, Integer.MAX_VALUE);
}

private boolean isValid(Node node, int minLimit, int maxLimit) {
    if (node == null)
        return true;
    return minLimit <= node.value && node.value <= maxLimit
            && isValid(node.left, minLimit, node.value)
            && isValid(node.right, node.value, maxLimit);
}
Ответил 10/09/2016 в 05:03
источник пользователем

голоса
-1
 private void validateBinarySearchTree(Node node) {
    if (node == null) return;

    Node left = node.getLeft();
    if (left != null) {
        if (left.getData() < node.getData()) {
            validateBinarySearchTree(left);
        } else {
            throw new IllegalStateException("Not a valid Binary Search tree");
        }
    }

    Node right = node.getRight();
    if (right != null) {
        if (right.getData() > node.getData()) {
            validateBinarySearchTree(right);
        } else {
            throw new IllegalStateException("Not a valid Binary Search tree");
        }
    }
}
Ответил 20/11/2017 в 20:30
источник пользователем

голоса
2

Вот мой ответ на питоне, он имеет все частные случаи рассмотрены и хорошо протестирован на hackerrank сайта

""" Node is defined as
class node:
    def __init__(self, data):
        self.data = data
        self.left = None
        self.right = None
"""

def checkBST(root):
    return checkLeftSubTree(root, root.left) and checkRightSubTree(root, root.right)

def checkLeftSubTree(root, subTree):
    if not subTree:
        return True
    else:
        return root.data > subTree.data \
        and checkLeftSubTree(root, subTree.left) \ 
        and checkLeftSubTree(root, subTree.right) \
        and checkLeftSubTree(subTree, subTree.left) \
        and checkRightSubTree(subTree, subTree.right)

def checkRightSubTree(root, subTree):
    if not subTree:
        return True
    else:
        return root.data < subTree.data \ 
        and checkRightSubTree(root, subTree.left) \
        and checkRightSubTree(root, subTree.right) \
        and checkRightSubTree(subTree, subTree.right) \
        and checkLeftSubTree(subTree, subTree.left)
Ответил 26/12/2017 в 18:04
источник пользователем

голоса
0

Один лайнер

bool is_bst(Node *root, int from, int to) {
   return (root == NULL) ? true :
     root->val >= from && root->val <= to &&
     is_bst(root->left, from, root->val) &&
     is_bst(root->right, root->val, to);
}

Довольно длинная линия, хотя.

Ответил 15/01/2018 в 19:12
источник пользователем

голоса
0

Вот решение в Java из класса алгоритма Седжвика. Проверьте полную реализацию BST здесь

Я добавил некоторые пояснительные комментарии

private boolean isBST() {
    return isBST(root, null, null);

}

private boolean isBST(Node x, Key min, Key max) {
    if (x == null) return true;
    // when checking right subtree min is key of x's parent
    if (min != null && x.key.compareTo(min) <= 0) return false;
    // when checking left subtree, max is key of x's parent
    if (max != null && x.key.compareTo(max) >= 0) return false;
    // check left subtree and right subtree
    return isBST(x.left, min, x.key) && isBST(x.right, x.key, max);

}
Ответил 30/10/2018 в 23:02
источник пользователем

голоса
0
  • iterativeФункция проверяет итеративно ли данное дерево является бинарным деревом поиска.
  • recurseФункция проверяет , рекурсивно ли данное дерево является двоичным деревом поиска или нет.
  • В iterativeфункции я использую BFS для проверки BST.
  • В recurseфункции я использую для проверки в глубину BST.
  • Оба решения имеют временную сложность O(n)
  • iterativeрешение имеет преимущество по сравнению с recurseраствором , и этим iterativeрешение делает раннюю остановку.
  • Даже recurseфункция может быть оптимизирована для ранней остановки по глобальному значению флага.
  • Идея как решения заключается в том, что левый ребенок должен находиться в пределах диапазона -бесконечности к значению родительского узла whihch является корневым узлом
  • Право ребенок должен быть в пределах от + бесконечности до значения родительского узла whihch является корневым узлом
  • И идти по сопоставлению значения текущего узла в пределах диапазона. Если значение какого-либо узла не находится в диапазоне, то вернуть значение False

    class Solution:
        def isValidBST(self, root):
            """
            :type root: TreeNode
            :rtype: bool
            """
            return self.iterative(root)
            # return self.recurse(root, float("inf"), float("-inf"))
    
        def iterative(self, root):
            if not root:
                return True
    
            level = [[root, -float("inf"), float("inf")]]
    
            while level:
                next_level = []
    
                for element in level:
                    node, min_val, max_val = element
                    if min_val<node.val<max_val:
                        if node.left:
                            next_level.append([node.left, min_val, node.val])
                        if node.right:
                            next_level.append([node.right, node.val, max_val])
                    else:
                        return False
                level = next_level
    
            return True
    
        def recurse(self, root, maxi, mini):
            if root is None:
                return True
    
            if root.val < mini or root.val > maxi:
                return False
    
            return self.recurse(root.left, root.val-1, mini) and self.recurse(root.right, maxi, root.val+1)
    
Ответил 01/11/2018 в 03:22
источник пользователем

голоса
0

реализация Python пример. В этом примере используется тип аннотации. Однако, так как класс Node использует себя, мы должны включать в себя в качестве первой линии модуля:

from __future__ import annotations

В противном случае, вы получите сообщение об name 'Node' is not definedошибке. Этот пример также использует в качестве класса - данных. Например , Для того, чтобы проверить , если это BST он использует рекурсию для проверки значений левых и правых узлов.

"""Checks if Binary Search Tree (BST) is balanced"""

from __future__ import annotations
import sys
from dataclasses import dataclass

MAX_KEY = sys.maxsize
MIN_KEY = -sys.maxsize - 1


@dataclass
class Node:
    value: int
    left: Node
    right: Node

    @property
    def is_leaf(self) -> bool:
        """Check if node is a leaf"""
        return not self.left and not self.right


def is_bst(node: Node, min_value: int, max_value: int) -> bool:
    if node.value < min_value or max_value < node.value:
        return False
    elif node.is_leaf:
        return True

    return is_bst(node.left, min_value, node.value) and is_bst(
        node.right, node.value, max_value
    )


if __name__ == "__main__":
    node5 = Node(5, None, None)
    node25 = Node(25, None, None)
    node40 = Node(40, None, None)
    node10 = Node(10, None, None)

    # balanced tree
    node30 = Node(30, node25, node40)
    root = Node(20, node10, node30)
    print(is_bst(root, MIN_KEY, MAX_KEY))

    # unbalanced tree
    node30 = Node(30, node5, node40)
    root = Node(20, node10, node30)
    print(is_bst(root, MIN_KEY, MAX_KEY))
Ответил 16/01/2019 в 00:10
источник пользователем

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more