二进制搜索树分段错误
Binary Search Tree segfaults
我已经为此挣扎了一段时间。我有一个BST,它的设计目的是在插入时遇到重复时递增计数器。这完全符合设计。
树将丢弃此元素,而树保持不变。但是,我想删除树中的原始元素,这样第三次插入重复元素不会增加计数器。当我运行程序时,我会出现segfault。请参阅下面的代码。GDB说segfault发生在InsertInto()方法中,ValGrind抱怨我找不到一堆内存泄漏。
任何帮助都将不胜感激。
struct BSTreeNode
{
int mData;
BSTreeNode *mLeft, *mRight;
BSTreeNode(int i)
{
mData = i;
mLeft = NULL;
mRight = NULL;
}
~BSTreeNode()
{
delete mLeft;
delete mRight;
}
};
class BSTree {
private:
BSTreeNode * mRoot;
bool mWithDeletion;
public:
int mDupCounter;
BSTree():mRoot(NULL),mDupCounter(0),mWithDeletion(false){}
BSTree(bool _withDelete):mRoot(NULL),mDupCounter(0),mWithDeletion(_withDelete){}
~BSTree()
{
delete mRoot;
}
BSTreeNode * FindSmallest(BSTreeNode *& _node)
{
if (!_node->mLeft)
return _node;
else
return FindSmallest(_node->mLeft);
}
void DeleteNode(BSTreeNode *& _node)
{
if (!_node->mLeft && !_node->mRight) // no subtrees
{
delete _node;
_node = NULL;
}
else if (_node->mLeft && !(_node->mRight)) // only left subtree
{
_node = _node->mLeft;
}
else if (_node->mRight && !(_node->mLeft)) // only right subtree
{
_node = _node->mRight;
}
else // both subtrees exist.
{
BSTreeNode * temp = FindSmallest(_node->mRight);
_node->mData = temp->mData;
DeleteNode(temp);
}
}
void InsertInto(BSTreeNode *& _node, int _valueToInsert)
{
if (!_node)
{
_node = new BSTreeNode(_valueToInsert);
}
else if (_valueToInsert < _node->mData)
{
InsertInto(_node->mLeft, _valueToInsert);
}
else if (_valueToInsert > _node->mData)
{
InsertInto(_node->mRight, _valueToInsert);
}
else
{
cout << "DUPLICATE FOUND!" << endl;
mDupCounter++;
// delete the node already in the tree if we must
if (mWithDeletion)
DeleteNode(_node);
}
cout << endl;
}
void InsertIntoRoot(int _valueToInsert)
{
InsertInto(mRoot, _valueToInsert);
}
};
您确定要通过删除节点来避免计算第三个重复吗?!即使你的删除代码是正确的,你仍然会计算第4个、第6个等重复。您模糊地隐藏了在没有节点的情况下发生重复的事实。
如果您在每个BSTreeNode中明确存储一个计数器,那就是在帮自己一个忙。我确信,与树中重复的非琐碎的删除/插入相比,开销可以忽略不计。
else
{
cout << "DUPLICATE FOUND!" << endl;
_node.DupCounter++;
}
如果不是为了性能,我甚至会忽略全局mDupCounter并遍历树来分析结果。如果需求发生变化,您可以有更多的选择来计算不同的数字,例如频率直方图或其他什么。
相关文章:
- 在某些循环内使用vector.push_back时出现分段错误
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 当我的阵列太大时出现分段错误
- 分段错误当我试图运行程序时出错
- 在c++中初始化矩阵时出现分段错误(核心转储)
- 尝试使用集合函数时出现分段错误
- 我无法缩小此分段错误的原因
- g++的分段错误(在NaN上使用to_string两次时)
- 为什么我使用 std::copy() 收到运行时错误(分段错误)?
- 为什么我的代码包含错误分段错误(核心转储)?
- 为什么会出现此错误?- 分段错误(核心转储)
- 意外的运行时错误(分段错误)
- C++将文本文件读入数组,运行错误:分段错误
- mmap 错误:分段错误/指针无效错误
- 在我的代码中找不到错误....分段错误
- 错误:分段故障(核心转储)阵列
- 用string.h将错误分段到队列中
- c++字符串流转换错误:分段错误
- 为什么我的代码显示错误分段错误(核心转储)