二进制搜索树左旋转
Binary search tree left rotation
我正在进行轮换,并尝试根据我调用的方法将已经进入二进制搜索树的课程向左或向右轮换。我的代码中有一个错误,我想我已经将其与旋转方法隔离开来,因为每次我在成功完成旋转后尝试打印时,它都会进入无限循环。在我的方法中是否存在某种类型的指针或调用混淆?我觉得我的逻辑是正确的,但似乎不知道错误在哪里(甚至不知道它是否在这个方法中)。
这是我的左旋转方法:
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);
}
相关文章:
- 有根的二进制搜索树.保留与其父级的链接
- 正在尝试重载二进制搜索树分配运算符
- 使用C++创建特殊的二叉搜索树
- 在递归二叉搜索树中搜索
- 在二叉搜索树中插入时出现分段错误
- C++二叉搜索树模板从函数返回节点
- 我可以在没有堆栈的情况下在二叉搜索树中实现迭代器吗?
- 在二叉搜索树C++中计算平均值
- 在字符串的二叉搜索树中搜索子字符串 - C++
- 在二叉搜索树中插入新元素
- 如何打印在二叉搜索树中找到的数据?
- 查找存储在二叉搜索树的所有非叶子中的数据总和?(返回整数的独立递归函数
- 这是一个二叉搜索树吗?黑客排名问题
- 二叉搜索树 - 实现"search"函数
- 二叉搜索树的 C++ 实现中的EXC_BAD_ACCESS错误
- 删除二叉搜索树 (C++) 中的单个元素
- 将值存储在带有C++的二叉搜索树中
- 二进制搜索树;自组织搜索/旋转C++
- 二进制搜索树左旋转
- 创建二叉搜索树类,一个节点在旋转后消失