Добавление элемента в дерево AVL.Дерево в настоящее время не имеет элементов.Я пытаюсь добавить один.Функция add работает нормально, за исключением того, что программа останавливается и заканчивается через 2 секунды, когда дело доходит до return new node(k)
.Почему это?
struct node
{
int key;
unsigned char height;
node *left;
node *right;
node(int k) {key = k; left = right = 0; height = 1;}
};
node *root;
node *add(node* p, int k)
{
if(!p)
{
return new node(k);
}
if(k < p->key)
p->left = add(p->left,k);
else
p->right = add(p->right,k);
return balance(p);
}
int main()
{
root = NULL;
add(root, 10);
printf("%d",root->key);
return 0;
}