gpt4 book ai didi

c++ - 二叉树 - 插入非空树

转载 作者:行者123 更新时间:2023-11-28 06:19:55 24 4
gpt4 key购买 nike

我正在尝试创建一个二叉树,但我在使用以下代码时遇到问题并收到错误:

expression must have pointer-to-class type.

我在 insert(tree->left, value) 和 insert(tree->权利,值(value));

void insert(node **tree, int value){
if (*tree == nullptr){
*tree = new node;
(*tree)->data = value;
(*tree)->left = nullptr;
(*tree)->right = nullptr;
}

else
if (value < (*tree)->data)
insert(tree->left, value);

else if (value >(*tree)->data)
insert(tree->right, value);

else
return;

最佳答案

假设node::leftnode::right都是node*类型,需要调用insert如下:

insert(&(*tree)->left, value);

或者,将树作为指针引用传递并为自己省去一堆显式解引用:

void insert(node *&tree, int value){
if (tree == nullptr){
tree = new node;
tree->data = value;
tree->left = nullptr;
tree->right = nullptr;
}
else if (value < tree->data)
insert(tree->left, value);
else if (value > tree->data)
insert(tree->right, value);
else
return;
}

关于c++ - 二叉树 - 插入非空树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29493035/

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