- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有在 BST 中旋转我的节点的函数:
void BST::rotate_with_left_child(BNode *&t){
BNode *t1 = t->left;
t->left = t1->right;
t1->right = t;
t->node_height = max(height(t->left),height(t->right))+1;
t1->node_height = max(height(t1->left),t->node_height)+1;
t = t1;
}
void BST::double_rotate_with_left_child(BNode *&t){
rotate_with_right_child(t->left);
rotate_with_left_child(t);
}
void BST::rotate_with_right_child(BNode *&t){
BNode *t1 = t->right;
t->right = t1->left;
t1->left = t;
t->node_height = max(height(t->right),height(t->left))+1;
t1->node_height = max(height(t1->right),t->node_height)+1;
t = t1;
}
void BST::double_rotate_with_right_child(BNode *&t){
rotate_with_left_child(t->right);
rotate_with_right_child(t);
}
并说我找到了一个我想旋转到树根的节点。我将如何编写一个函数来执行此操作?
最佳答案
注意: 以下代码根本没有经过测试。它只是太说明了这些想法。代码一直在底部。
假设:
我假设您通过某种搜索例程获得了一个节点。现在,想法是,简单地维护:
例如,给定这棵树:
15 / \ 2 35 / \ 28 42 / \ 19 31
and we searched for the key 19
, which is inside the tree. Now, we want to rotate 19 all the way to the top.
NodeStack
, a stack of nodes from bottom of stack to top: [15, 35, 28, 19]
<-- top of stack
DirStack
, a stack of link directions traversed: [RIGHT, LEFT, LEFT]
<-- top of stack
We are assuming as search hit here. So the first thing we should do is to retrieve the topmost element of NodeStack
, which is the node we want to rotate to the top. In this case, it is the node with key 19
. After this step, both stacks look like:
NodeStack
: [15, 35, 28]
<-- top of stack
DirStack
: [RIGHT, LEFT, LEFT]
<-- top of stack
Next, the main loop runs until DirStack
is empty. We pop one element from both stacks. The element popped from NodeStack
is the parent of the node we wish to rotate to the top, and the element popped from DirStack
indicates the direction of the link from the node we just popped to the future root node.
At the first iteration of the loop, we have the node 28
and link direction LEFT
, so node 19
is the left child of node 28
.
It should not be hard to see that we should rotate opposite to the direction that we just popped, so we should rotate the parent node left if the direction is RIGHT
, and rotate the parent node right if the direction is LEFT
. Since the direction here is LEFT
, we rotate the parent node 28
right. This can be achieved by calling the rotate_with_left_child
function on node 28
.
The tree becomes
15 / \ 2 35 / \ 19 42 \ 28 \ 31
notice that 28
becomes a right child, hence this is a right rotation. I'm pretty sure this is the correct terminology. As wikipedia is down right now, I cannot verify this, but this question shows that I'm using the correct terminology:
Code with explanation for binary tree rotation (left OR right)
State of the stacks now:
NodeStack
: [15, 35]
<-- top of stack
DirStack
: [RIGHT, LEFT]
<-- top of stack
The stacks are not empty, so we pop 35
and LEFT
from the two stacks. We perform a right rotation using the rotate_with_left_child function on the node 35
, to get this tree:
15 / \ 2 19 \ 35 / \ 28 42 \ 31
Our node is now closer to becoming root. Stacks now:
NodeStack
: [15]
DirStack
: [RIGHT]
We pop node 15
and direction RIGHT
. Now, we perform a left rotation using the rotate_with_right_child
function on node 15
, and we obtain this final tree:
19 / \ 15 35 / / \ 2 28 42 \ 31
Tadah! We are now done. Here's the code, using std::stack
from STL.
// NOTE: None of the code here is tested, so some errors are expected.
// Used to indicate direction of links traversed during the search
enum Direction {
LEFT, RIGHT
};
// This function rotates the node at the top of nodeStack to the root of the tree.
// It assumes that the nodeStack is non-empty, and that nodeStack has one more
// element than dirStack
//
// nodeStack - stack of nodes encountered during search
// dirStack - direction of links traversed during search
void rotate_to_top(stack<BSTNode *>& nodeStack, stack<Direction>& dirStack) {
// remove the future root node. actually this assignment is not needed
// NOTE: You might also want to check if the nodeStack is empty before doing this
BSTNode* root = nodeStack.top();
nodeStack.pop();
// main loop. this is done until the dirStack is empty
while (!dirStack.empty()) {
Direction d = dirStack.top();
dirStack.pop();
BSTNode *par = nodeStack.top();
nodeStack.top();
// perform the proper rotation
if (d == LEFT) {
rotate_with_left_child(par);
} else {
rotate_with_right_child(par);
}
}
}
希望对您有所帮助 =)
关于c++ - 将节点旋转到 BST 的根,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19826630/
...沮丧。我希望我的游戏仅在横向模式下运行。我已将适当的键/值添加到 Info.plist 文件中,以强制设备方向在启动时正确。 我现在正在尝试旋转 OpenGL 坐标空间以匹配设备的坐标空间。我正
我如何创建一个旋转矩阵,将 X 旋转 a,Y 旋转 b,Z 旋转 c? 我需要公式,除非您使用的是 ardor3d api 的函数/方法。 矩阵是这样设置的 xx, xy, xz, yx, yy, y
假设我有一个包含 3 个 vector 的类(一个用于位置,一个用于缩放,一个用于旋转)我可以使用它们生成一个变换矩阵,该矩阵表示对象在 3D 空间中的位置、旋转和大小。然后我添加对象之间的父/子关系
所以我只是在玩一个小的 javascript 游戏,构建一个 pacman 游戏。你可以在这里看到它:http://codepen.io/acha5066/pen/rOyaPW 不过我对旋转有疑问。你
在我的应用程序中,我有一个 MKMapView,其中显示了多个注释。 map 根据设备的航向旋转。要旋转 map ,请执行以下语句(由方法 locationManager 调用:didUpdateHe
使用此 jquery 插件时:http://code.google.com/p/jqueryrotate/wiki/Documentation我将图像旋转 90 度,无论哪个方向,它们最终都会变得模糊
我有以下代码:CSS: .wrapper { margin:80px auto; width:300px; border:none; } .square { widt
本篇介绍Manim中的两个旋转类的动画,名称差不多,分别是Rotate和Rotating。 Rotate类主要用于对图形对象进行指定角度、围绕特定点的精确旋转,适用于几何图形演示、物理模拟和机械运动
我只想通过小部件的轴移动图像并围绕小部件的中心旋转(就像任何数字绘画软件中的 Canvas ),但它围绕其左顶点旋转...... QPainter p(this); QTransform trans;
我需要先旋转图像,然后再将其加载到 Canvas 中。据我所知,我无法使用 canvas.rotate() 旋转它,因为它会旋转整个场景。 有没有好的JS方法来旋转图片? [不依赖于浏览器的方式] 最
我需要知道我的 Android 设备屏幕何时从一个横向旋转到另一个横向(rotation_90 到 rotation_270)。在我的 Android 服务中,我重新实现了 onConfigurati
**摘要:**本篇文章主要讲解Python调用OpenCV实现图像位移操作、旋转和翻转效果,包括四部分知识:图像缩放、图像旋转、图像翻转、图像平移。 本文分享自华为云社区《[Python图像处理] 六
我只是在玩MTKView中的模板设置;并且,我一直在尝试了解以下内容: 相机的默认位置。 使用MDLMesh和MTKMesh创建基元时的默认位置。 为什么轮换还涉及翻译。 相关代码: matrix_f
我正在尝试使用包 dendexend 创建一个树状图。它创建了非常好的 gg 树状图,但不幸的是,当你把它变成一个“圆圈”时,标签跟不上。我将在下面提供一个示例。 我的距离对象在这里:http://s
我想将一个完整的 ggplot 对象旋转 90°。 我不想使用 coord_flip因为这似乎会干扰 scale="free"和 space="free"使用刻面时。 例如: qplot(as.fac
我目前可以通过首先平移到轴心点然后执行旋转最后平移回原点来围绕轴心点旋转。在我的例子中,我很容易为肩膀做到这一点。但是,我不知道如何为前臂添加绕肘部的旋转。 我已经尝试了以下围绕肘部旋转的前臂: 平移
我想使用此功能旋转然后停止在特定点或角度。现在该元素只是旋转而不停止。代码如下: $(function() { var $elie = $("#bkgimg");
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
我正在尝试创建一个非常简单的关键帧动画,其中图形通过给定的中点从一个角度旋转到另一个角度。 (目的是能够通过大于 180 度的 OBTUSE 弧角来制作旋转动画,而不是让动画“作弊”并走最短路线,即通
我需要旋转 NSView 实例的框架,使其宽度变为其高度,其高度变为其宽度。该 View 包含一个字符串,并且该字符串也被旋转,这一点很重要。 我查看了 NSView 的 setFrameRotati
我是一名优秀的程序员,十分优秀!