我正在构建一个二叉搜索树,以下是add函数:
void BinaryTree::add(int value, Node*& node, Node*& parent) {
if(!node) {
node = new Node(value);
node->parent = parent;
}
else if(node->key < value)
this->add(value, node->rightNode, node);
else if(node->key > value)
this->add(value, node->leftNode, node);
}
我想为最后两个(节点,父节点)参数设置默认参数:
void add(int value, Node*& node = root , Node*& parent = nullptr);
其中root是该类的字段。
这似乎不适用于任何一种情况。我该如何实现它,这里有什么问题? 谢谢!
答案 0 :(得分:3)
您无法初始化对nullptr
的引用。它们必须是有效的对象。要使root
defualt对象,您可以添加具有相同名称的新函数
void BinaryTree::add(int value) {
Node* emptyParent = nullptr;
add(value, root, emptyParent);
}