我的解决办法是像我的二叉树插入逻辑的缺陷在哪里?
/*
Node is defined as
typedef struct node
{
int data;
node * left;
node * right;
}node;
*/
node * insert (node * root, int value)
{
bool inTreeAlready = false;
node * cur = root;
while(cur != NULL)
{
if(cur->data < value)
cur = cur->right;
else if(cur->data > value)
cur = cur->left;
else
{
inTreeAlready = true;
break;
}
}
if(!inTreeAlready)
{
cur = new node;
cur->data = value;
cur->left = NULL;
cur->right = NULL;
}
return root;
}
其中提示的问题说你应该插入后返回树的根。
这显然错了,因为输出是
Wrong Answer! Some possible errors: 1. You returned a NULL value from the function. 2. There is a problem with your logic 3. You are printing some value from the function
这是不是很描述。
我仔细检查了我的逻辑,不知道交易是什么。
我看到你创建一个新的节点,但我没有看到你实际将它链接到树上。它不能从'root'获得 - 它只是被泄露。如果你从一棵空树('root == NULL')开始,你也清楚地以一棵空树结尾('root'仍然是'NULL') - 所以你永远不会得到第一个节点。 –
奇怪的是这段代码打印了一些东西,因为它没有任何'printf'调用。 – immibis