我正在创建一个二叉树程序,我想重载一些运算符。我试过重载+运算符,这样当我写myTree + 5
之类的东西时,它会在树上添加5作为节点。
这是我的代码:
BST myTree;
void operator+(BST left, int right) {
myTree.addLeaf(right);
}
int main() {
vector<int> treeKeyList;
srand((unsigned)time(NULL));
int before = rand() % 20 + 1;
for (int i = 0; i < before; i++) {
int after = rand() % 20 + 1;
treeKeyList.push_back(after);
cout << treeKeyList[i] << " ";
}
cout << endl;
for (int i = 0; i < treeKeyList.size(); i++) {
myTree + treeKeyList[i];
}
}
目前,它似乎在一个循环中运行良好,但是当它尝试添加第二个值并出现分段错误时崩溃。我认为问题必须在我所显示的代码中,因为在我添加重载之前它工作得很好。如果我这样做了:
for (int i = 0; i < treeKeyList.size(); i++) {
myTree.addLeaf(treeKeyList[i]);
}
它绝对正常。有什么想法吗?
答案 0 :(得分:1)
您很可能需要将BST作为参考。另请考虑使用+=
代替+
。