AVL二进制树旋转和删除树的C 问题
c++ Issue with AVL Binary tree rotations and deleting tree
我正在处理AVL二进制树实现,除了旋转和删除功能外,我的大部分代码都可以使用。我尝试了不同的实施方法,但我仍然无法弄清楚自己在做什么。如果有人能帮助我解决解决方案,将不胜感激。如果我评论平衡函数,则代码将根据需要工作,并从导入的文本文件中插入所有单词,但是当我尝试平衡节点的那一刻,代码爆炸了。由于某种原因,我的:
删除节点;
我的代码部分,但我不确定为什么这是一个问题。递归穿过树没有问题,但是一旦达到删除节点部分,就会有问题,这对我来说没有任何意义...
标题:
#ifndef AVLBINARYTREE_H
#define AVLBINARYTREE_H
#include <iostream>
#include <string>
using namespace std;
class LinkedBinaryTree {
private:
struct Node {
string word;
Node* left;
Node* right;
Node* parent;
int wordCount;
int height;
Node() : word(), left(NULL), right(NULL), parent(NULL), wordCount(1), height(0) {}
Node(string s, Node* l, Node* r, Node* p) {
word = s;
left = NULL;
right = NULL;
parent = p;
wordCount = 1;
height = 0;
}
};
Node* _root;
public:
LinkedBinaryTree();
~LinkedBinaryTree();
void destroyTree();
void destroyTree(Node* node);
void insert(string word);
void display(Node* ptr, int level);
Node* root();
void inOrder(Node* node);
int avlNum(Node* node);
int getNumWords();
void insertNode(Node* node, string word);
int height(Node* node);
int bfactor(Node* node);
void fixHeight(Node* node);
void balance(Node* node);
void rightRotate(Node* node);
void leftRotate(Node* node);
void rightLeftRotate(Node* node);
void leftRightRotate(Node* node);
int n;
};
#endif
.cpp:
#include "AVLBinaryTree.h"
#include <algorithm>
void LinkedBinaryTree::inOrder(Node* node) {
if (node == NULL)
return;
inOrder(node->left);
cout << node->wordCount << " " << node->word << endl;
inOrder(node->right);
}
void LinkedBinaryTree::rightRotate(Node* node) {
Node* temp;
temp = node->left;
node->left = temp->right;
//node->left->parent = node;
temp->parent = node->parent;
temp->right = node;
node->parent = temp;
node = temp;
if (temp->parent == NULL) {
_root = node;
}
fixHeight(node);
fixHeight(node->right);
fixHeight(node->left);
}
void LinkedBinaryTree::leftRotate(Node* node) {
Node* temp;
temp = node->right;
node->right = temp->left;
temp->parent = node->parent;
temp->left = node;
node->parent = temp;
node = temp;
if (temp->parent == NULL) {
_root = node;
}
fixHeight(node);
fixHeight(node->right);
fixHeight(node->left);
}
void LinkedBinaryTree::rightLeftRotate(Node* node) {
rightRotate(node->left);
leftRotate(node);
}
void LinkedBinaryTree::leftRightRotate(Node* node) {
leftRotate(node->right);
rightRotate(node);
}
int LinkedBinaryTree::height(Node* node) {
int h = 0;
if (node != NULL) {
h = node->height;
}
return h;
}
int LinkedBinaryTree::bfactor(Node* node) {
return height(node->right) - height(node->left);
}
void LinkedBinaryTree::fixHeight(Node* node) {
int hl = height(node->left);
int hr = height(node->right);
node->height = (hl > hr ? hl : hr) + 1;
}
int LinkedBinaryTree::avlNum(Node* node) {
int leftH = height(node->left);
int rightH = height(node->right);
int avlNum = rightH - leftH;
return avlNum;
}
LinkedBinaryTree::LinkedBinaryTree() {
_root = NULL;
}
LinkedBinaryTree::~LinkedBinaryTree() {
destroyTree();
}
void LinkedBinaryTree::destroyTree() {
destroyTree(_root);
}
//**********************************************************
// destroyTree is called by the destructor. It deletes
// all nodes in the tree.
//**********************************************************
void LinkedBinaryTree::destroyTree(Node* node) {
if (node != NULL) {
if (node->left != NULL)
destroyTree(node->left);
if (node->right != NULL)
destroyTree(node->right);
delete node;
}
}
void LinkedBinaryTree::insertNode(Node* node, string word) {
if (word < node->word) {
if (node->left != NULL)
insertNode(node->left, word);
else {
node->left = new Node(word, NULL, NULL, node);
n++;
fixHeight(node->left);
}
}
else if (word > node->word) {
if (node->right != NULL)
insertNode(node->right, word);
else {
node->right = new Node(word, NULL, NULL, node);
n++;
fixHeight(node->right);
}
}
else if (word == node->word) {
node->wordCount++;
}
balance(node);
}
void LinkedBinaryTree::insert(string word) {
if (_root == NULL) {
_root = new Node(word, NULL, NULL, NULL);
n++;
}
else {
insertNode(_root, word);
}
}
void LinkedBinaryTree::display(Node* ptr, int level) {
int i;
if (ptr != NULL)
{
display(ptr->right, level + 1);
printf("n");
if (ptr == _root)
cout << "Root -> ";
for (i = 0; i < level && ptr != _root; i++)
cout << " ";
cout << ptr->word;
display(ptr->left, level + 1);
}
}
LinkedBinaryTree::Node * LinkedBinaryTree::root() {
return _root;
}
void LinkedBinaryTree::balance(Node* node) {
fixHeight(node);
if (bfactor(node) == 2) {
if (bfactor(node->right) < 0)
rightRotate(node->right);
else
leftRotate(node);
}
if (bfactor(node) == -2) {
if (bfactor(node->left) > 0)
leftRotate(node->left);
else
rightRotate(node);
}
}
int LinkedBinaryTree::getNumWords() {
return n;
}
主:
#include "AVLBinaryTree.h"
#include <iostream>
#include <fstream>
#include <string>
#include <queue>
#include <vector>
#include <functional>
int main(int argv, char *argc[]) {
LinkedBinaryTree t;
string word("Test."), lastword("");
for (int i = 0; i < argv; i++)
cout << argc[i] << endl;
if (argv < 2) {
cerr << "No input file specified" << endl;
system("pause");
exit(1);
}
for (int count = 1; count < argv; count++)
{
ifstream input(argc[count]);
if (!input) {
cerr << "Cannot open input file" << argc[count] << endl;
system("pause");
exit(1);
}
while (input >> word)
{
transform(word.begin(), word.end(), word.begin(), ::tolower);
word.erase(remove_if(word.begin(), word.end(), ispunct));
t.insert(word);
}
}
t.inOrder(t.root());
cout << endl;
cout << "--------" << endl;
cout << t.getNumWords() << " " << "Total number of different words";
cout << endl;
/*t.insert("Yes");
t.insert("No");
t.insert("Maybe");
t.insert("Hopefully");
t.insert("Absolutely");
t.display(t.root(), 1);
cout << endl;
cout << endl;
t.inOrder(t.root());
*/
system("PAUSE");
t.~LinkedBinaryTree();
return EXIT_SUCCESS;
}
预先感谢!
旋转函数中的 node = temp;
线正在更改属于函数的指针的本地值,而不是存储在树上的值。例如,当您致电rightRotate(node->right)
时,应更新通话后node->right
的值相同。
可能的解决方案包括将节点指针传递到旋转函数中作为参考(void LinkedBinaryTree::rightRotate(Node*& node)
),以便更新原始值,或者返回更新值(Node *LinkedBinaryTree::rightRotate(Node* node)
)并适当存储该值。
您的balance
功能和其他旋转功能可能会类似地折磨。
相关文章:
- 移动赋值运算符;尝试引用已删除的函数.我该如何解决这个问题?
- 目录删除 MFC 的问题
- 关于比较两个无序数组并删除 a[] 中可以在 b[] 中找到的元素的问题
- 在 C++ 的自定义运算符中删除与删除[](不同于常见的删除与删除[]问题)
- C++删除/(递归)对象销毁问题
- Sinlge 链表,C++,删除所有和搜索功能的问题
- C++ 从链表中删除项目时出现问题
- delete[]有问题,如何部分删除内存
- 关于从驱动器中删除文件的问题
- 删除数组 c++ 崩溃问题
- 为什么当我从语句检查中删除"+ mod"时,以下程序给出错误的答案。问题链接:https://www.codechef.com/problems/FFC219B
- 在 QLayout 中创建和删除自定义 QWidgets 时出现 RAM 问题
- 代码问题.使用矢量删除相同的数字,除了它的最后一个入口
- 使用安全零内存新建/删除时出现问题
- 从ints向量删除int的问题
- 如何解决删除其他人之间共享的对象的问题
- 双向链表问题(特别是复制构造函数和删除函数)
- C++二进制搜索树删除问题
- 回文查找器:非字母数字字符删除问题
- QSA 的子对象删除问题