Назад к вопросам
Junior — Middle
89
Можете объяснить, что такое структура данных бинарное дерево поиска и как она работает?
Ответ от нейросети
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