运算符重载的分段错误

时间:2015-03-25 22:48:25

标签: c++ operator-overloading binary-tree

我正在创建一个二叉树程序,我想重载一些运算符。我试过重载+运算符,这样当我写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]);
}

它绝对正常。有什么想法吗?

1 个答案:

答案 0 :(得分:1)

您很可能需要将BST作为参考。另请考虑使用+=代替+