gpt4 book ai didi

c++ - 通过引用传递指针时出错

转载 作者:行者123 更新时间:2023-12-01 14:53:06 25 4
gpt4 key购买 nike

我将提供指向这个非常相似的问题的链接:C++ initial value of reference to non-const must be an lvalue
错误是相同的(对非const的引用的初始值必须是一个左值),但情况有所不同。与该示例相反,在我的函数中,确实需要修改指针。我正在编写一个递归函数,将一个节点添加到二进制搜索树中。该功能包括在此处。

1   void BST::insert(BSTNode*& current, BSTNode*& newNode)
2 {
3 //If empty, assign
4 if (current == nullptr)
5 current = newNode;
6
7 //If less, go left
8 else if (newNode->getEng() <= current->getEng())
9 insert(current->getLeft(), newNode);
10
11 //If greater, go right
12 else
13 insert(current->getRight(), newNode);
14 }

我在第9行和第13行收到错误。如图所示,我通过引用传递了当前指针和newNode指针,但是newNode并没有问题,只有 current->getLeft()current->getRight()语句。在我链接的问题中,有人评论说错误是因为仅当在函数中修改值时才应使用按引用传递。在 current == nullptr的第一种情况下,该值已修改,因此我不确定该怎么做。

编辑以包括BSTNode类

class BSTNode
{
public:
BSTNode();
BSTNode(char, string);

void setLeft(BSTNode* newLeft) { left = newLeft; }
void setRight(BSTNode* newRight) { right = newRight; }
BSTNode* getLeft() { return left; }
BSTNode* getRight() { return right; }
char getEng() { return Eng; }
string getMorse() { return Morse; }

private:
char Eng;
string Morse;
BSTNode* left;
BSTNode* right;
};

这是我的BST类(class):

class BST
{
public:
BST(string fileName);
~BST();

bool isEmpty();
void addNode(char english, string morse);
void insert(BSTNode** current, BSTNode*& newNode);

//bool searchTree(char english, string& morse);

private:
BSTNode* root;
int nodeCount;
};

最佳答案

编译器使您免于破损。在插入第9行的调用中,您将向insert传递对current->getLeft()返回的临时引用。如果您随后修改该临时文件,修改将丢失。修复getLeft以返回可修改的引用。

关于c++ - 通过引用传递指针时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61036787/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com