从bst删除节点时出现分段错误。
我为delp制作了delnode函数
从二叉搜索树中删除节点
我正在三种情况下使用它
-当节点有两个子节点时
-当节点是叶节点时
-当只有我们要删除的节点的子节点时。
代码-
#include <stdio.h>
#include <stdlib.h>
struct node{
int data;
struct node * left ;
struct node * right ;
};
struct node * newnode(int d){
struct node * nn = (struct node *)malloc(sizeof(struct node));
nn->data = d;
nn->left = NULL;
nn->right = NULL;
return nn;
}
struct node * inserttree(struct node * r , int d){
if(!r){
return newnode(d);
}
if(d<=r->data){
r->left = inserttree(r->left,d);
}else{
r->right = inserttree(r->right,d);
}
return r;
}
void inorder(struct node * r){
if(r){
inorder(r->left);
printf("%d ",r->data);
inorder(r->right);
}
}
struct node * searchkey(struct node * r,int val){
if(r){
if(r->data == val){
return r;
}
searchkey(r->left,val);
searchkey(r->right,val);
return r;
}
}
struct node * searchabovekey(struct node * r , int val){
if(r){
if(r->left->data==val || r->right->data==val){
return r;
}
searchabovekey(r->left,val);
searchabovekey(r->right,val);
return r;
}
}
struct node * findinorderpredecessor(struct node * t){
if(t){
struct node * temp = t->left;
while(t->right){
t=t->right;
}
return t;
}
}
void delnode(struct node * r, int val){
if(r){
struct node * keynode = searchkey(r,val);
struct node * abovekeynode = searchabovekey(r,val);
//three cases
//first case two child present
if(keynode->left!=NULL && keynode->right!=NULL){
struct node * inopre = findinorderpredecessor(keynode);
keynode->data = inopre->data;
struct node * aboveinopre = searchabovekey(inopre,inopre->data);
if(aboveinopre->left == inopre){
aboveinopre->left = NULL;
free(inopre);
return;
}
if(aboveinopre->right == inopre){
aboveinopre->right = NULL;
free(inopre);
return;
}
}else if(keynode->left == NULL && keynode->right == NULL){
//second case no child present
if(abovekeynode->left == keynode){
abovekeynode->left = NULL;
free(keynode);
return;
}
if(abovekeynode->right == keynode){
abovekeynode->right = NULL;
free(keynode);
return;
}
}else{
//third case when only one child is present
if(abovekeynode->left==keynode){
if(keynode->left!=NULL){
abovekeynode->left=keynode->left;
free(keynode);
return;
}
if(keynode->right!=NULL){
abovekeynode->left=keynode->right;
free(keynode);
return;
}
}
if(abovekeynode->right==keynode){
if(keynode->left!=NULL){
abovekeynode->right=keynode->left;
free(keynode);
return;
}
if(keynode->right!=NULL){
abovekeynode->right=keynode->right;
free(keynode);
return ;
}
}
}
}
}
int main()
{
printf("enter n : ");
int n;
scanf("%d",&n);
int a[n];
printf("\nenter the values :");
for(int i=0;i<n;i++){
scanf("%d",&a[i]);
}
struct node * root = NULL;
root=inserttree(root,a[0]);
for(int i=1;i<n;i++){
inserttree(root,a[i]);
}
printf("\ninorder is :\n");
inorder(root);
while(1){
printf("\nwould you like to delete?\n1.yes\n2.no\n");
int c;
scanf("%d",&c);
if(c==2){
return 0;
}
if(c==1){
printf("\nenter the data to delete : ");
int d;
scanf("%d",&d);
delnode(root,d);
printf("\ninorder is :\n");
inorder(root);
printf("\n");
}
}
return 0;
}
答案 0 :(得分:0)
在searchabovekey函数中,当您测试if(node-> left-> data = val ...时,左侧或右侧节点可以为空,因此您试图读取未分配内存的区域。首先,如果node-> left和node-> right不为空。