這是用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