这是用C编码的二叉搜索树的删除功能,但这不起作用。应该删除的节点被垃圾值替换。二叉搜索树的删除功能无法正常工作
void delete(struct node* root,int data)
{
{
struct node* t1;
if(root==0) {
printf("element not found\n");
} else if(data>root->data) {
delete(root->right,data);
} else if(data<root->data) {
delete(root->left,data);
} else {
if(root->right&&root->left) {
t1=findmin(root->right);
root->data=t1->data;
free(t1);
} else {
t1=root;
if(root->right) {
root=root->right;
} else if(root->left) {
root=root->left;
}
free(t1);
}
}
}
它本身工作,但节点没有被删除,并被一些垃圾值所取代。
struct node* findmin(struct node* t) {
if(t==NULL) {
return NULL;
} else if(t->left) {
findmin(t->left);
} else
return t;
}
请比'不正常工作'更具体,并改善代码格式。通过[ask howto](https://stackoverflow.com/help/how-to-ask) – creimers
'findmin(t-> left);'应该是'return findmin(t->左);'!编译器最有可能告诉你(或多或少间接)。 – alk
我增加了return.it没有区别。通过“不正常工作”,我的意思是所需的既不删除也不删除。唯一的变化是,它在第一次调用时被替换为0,并且下一次被替换为垃圾值 – thehalberdier