二进制搜索树左旋转

Binary search tree left rotation

本文关键字:旋转 搜索树 二进制      更新时间:2023-10-16

我正在进行轮换,并尝试根据我调用的方法将已经进入二进制搜索树的课程向左或向右轮换。我的代码中有一个错误,我想我已经将其与旋转方法隔离开来,因为每次我在成功完成旋转后尝试打印时,它都会进入无限循环。在我的方法中是否存在某种类型的指针或调用混淆?我觉得我的逻辑是正确的,但似乎不知道错误在哪里(甚至不知道它是否在这个方法中)。

这是我的左旋转方法:

bool BinarySearchTree::leftRotate(string number)
{
Course *x, *y;
if (treeSearch(number) == NULL){
    return false;
}
else{
    x = treeSearch(number);
}
if (x->getRight() == NULL){
    return false;
}
else{
    y = x->getRight();
    x->setRight(y->getLeft());
}
if (y->getLeft() != NULL){
    y->getLeft()->setParent(x);
}
y->getParent()->setParent(x);
if(x->getParent() == NULL){
    root = y;
}
else if( x->getParent()->getRight() == x){
    x->getParent()->setLeft(y);
}
else{
    x->getParent()->setRight(y);
}
    y->setLeft(x);
    x->setParent(y);
return true; 
}

提前谢谢。

看起来像

y->getParent()->setParent(x);

应该是

y->setParent(x->getParent());

但是在检查x->getParent是否为NULL之后执行此操作。

类似的东西

// Remove this line: y->getParent()->setParent(x);
if(x->getParent() == NULL){
    root = y;
}
else if( x->getParent()->getRight() == x){
    y->setParent(x->getParent());   // Insert this line
    x->getParent()->setLeft(y);
}

编辑:再看一遍代码,我认为即使x->getParent()返回NULL,也应该调用y->setParent(x->getParent())。原因是,如果y成为新的根,y也应将Parent设置为NULL。

因此,下面的代码可能是一个更好的答案:

// Remove this line: y->getParent()->setParent(x);
y->setParent(x->getParent());   // Insert this line
if(x->getParent() == NULL){
    root = y;
}
else if( x->getParent()->getRight() == x){
    x->getParent()->setLeft(y);
}