Sobes.tech
Назад к вопросам
Junior — Middle
90

Можете объяснить, что такое структура данных бинарное дерево поиска и как она работает?

Ответ от нейросети

sobes.tech AI

Бинарное дерево поиска (Binary Search Tree, BST) — это структура данных в виде дерева, где каждый узел содержит ключ, а для каждого узла выполняется условие:

  • Все ключи в левом поддереве меньше ключа узла.
  • Все ключи в правом поддереве больше ключа узла.

Это позволяет эффективно выполнять операции поиска, вставки и удаления элементов со средней сложностью O(log n), если дерево сбалансировано.

Пример вставки и поиска в BST на JavaScript:

class Node {
  constructor(key) {
    this.key = key;
    this.left = null;
    this.right = null;
  }
}

class BST {
  constructor() {
    this.root = null;
  }

  insert(key) {
    const newNode = new Node(key);
    if (!this.root) {
      this.root = newNode;
      return;
    }
    let current = this.root;
    while (true) {
      if (key < current.key) {
        if (!current.left) {
          current.left = newNode;
          break;
        }
        current = current.left;
      } else {
        if (!current.right) {
          current.right = newNode;
          break;
        }
        current = current.right;
      }
    }
  }

  search(key) {
    let current = this.root;
    while (current) {
      if (key === current.key) return true;
      current = key < current.key ? current.left : current.right;
    }
    return false;
  }
}

const tree = new BST();
tree.insert(10);
tree.insert(5);
tree.insert(15);
console.log(tree.search(5)); // true
console.log(tree.search(20)); // false