二叉查找樹是滿足以下條件的二叉樹:
1、左子樹上的所有節(jié)點(diǎn)值均小于根節(jié)點(diǎn)值,
2、右子樹上的所有節(jié)點(diǎn)值均不小于根節(jié)點(diǎn)值,
3、左右子樹也滿足上述兩個(gè)條件。
二叉查找樹的插入過程如下:
1.若當(dāng)前的二叉查找樹為空,則插入的元素為根節(jié)點(diǎn),
2.若插入的元素值小于根節(jié)點(diǎn)值,則將元素插入到左子樹中,
3.若插入的元素值不小于根節(jié)點(diǎn)值,則將元素插入到右子樹中。
二叉查找樹的刪除,分三種情況進(jìn)行處理:
1.p為葉子節(jié)點(diǎn),直接刪除該節(jié)點(diǎn),再修改其父節(jié)點(diǎn)的指針(注意分是根節(jié)點(diǎn)和不是根節(jié)點(diǎn)),如圖a。
2.p為單支節(jié)點(diǎn)(即只有左子樹或右子樹)。讓p的子樹與p的父親節(jié)點(diǎn)相連,刪除p即可;(注意分是根節(jié)點(diǎn)和不是根節(jié)點(diǎn));如圖b。
3.p的左子樹和右子樹均不空。找到p的后繼y,因?yàn)閥一定沒有左子樹,所以可以刪除y,并讓y的父親節(jié)點(diǎn)成為y的右子樹的父親節(jié)點(diǎn),并用y的值代替p的值;或者方法二是找到p的前驅(qū)x,x一定沒有右子樹,所以可以刪除x,并讓x的父親節(jié)點(diǎn)成為y的左子樹的父親節(jié)點(diǎn)。如圖c。
插入節(jié)點(diǎn)的代碼:
pnode BT = NULL;
//遞歸方法插入節(jié)點(diǎn)
pnode insert(pnode root, int x)
{
pnode p = (pnode)malloc(LEN);
p->val = x;
p->lchild = NULL;
p->rchild = NULL;
if(root == NULL){
root = p;
}
else if(x < root->val){
root->lchild = insert(root->lchild, x);
}
else{
root->rchild = insert(root->rchild, x);
}
return root;
}
//非遞歸方法插入節(jié)點(diǎn)
void insert_BST(pnode q, int x)
{
pnode p = (pnode)malloc(LEN);
p->val = x;
p->lchild = NULL;
p->rchild = NULL;
if(q == NULL){
BT = p;
return ;
}
while(q->lchild != p && q->rchild != p){
if(x < q->val){
if(q->lchild){
q = q->lchild;
}
else{
q->lchild = p;
}
}
else{
if(q->rchild){
q = q->rchild;
}
else{
q->rchild = p;
}
}
}
return;
}
新聞熱點(diǎn)
疑難解答
圖片精選