数据结构--6.5二叉排序树(插入,查找和删除)

目录

一、创建

二、插入

三、删除


二叉排序树(Binary Sort Tree)又称为二叉查找树,它或者是一棵空树,或者是具有下列性质的二叉树:

------若它的左子树不为空,则左子树上所有结点的值均小于它的根结构的值;

------若它的右子树不为空,则右子树上所有结点的值均大于它的根结构的值;

------它的左、右子树也分为二叉排序树(递归)。

一、创建

cpp 复制代码
//二叉树的二叉链表结点结构定义
typedef struct BiTNOde
{
	int data;
	struct BiTNode * lchild,*rchild;
}BiTNode, *BiTree;

//递归查找二叉排序树T中是否存在key
//指针f指向T的双亲,其初始值调用值为NULL
//若查找成功,则指针p指向该数据元素结点,并返回TRUE
//否则指针p指向查找路径上访问的最后一个结点,并返回FALSE
Status SearchBST(BiTree T,int key,BiTree f,BiTree *p)
{
	if(!T)   //查找不成功
	{
		*p = f;
		return FALSE; 
	} 
	else if(key == T->data)
	{
		return SearchBST(T->lchild,key,T,p);    //在左子树继续查找 
	}
	else
	{
		return SearchBST(T->rchild,key,T,p);   //在右子树继续查找 
	} 
} 

二、插入

cpp 复制代码
//insertBST
//当二叉排序树T中不存在关键字等于key的数据元素时
Status InsertBST(BiTree *T,int key)
{
	BiTree p,s;
	if(!SearchBST(*T,key,NULL,&p))
	{
		s = (BiTree)malloc(sizeof(BiTNode));
		s->data = key;
		s->lchild = s->rchild = NULL;
		
		if(!p)		//查找不到key 
		{
			*T = s; //插入s为新的根结点 
		}
		else if(key < p->data)
		{
			p->lchild = s; //插入s为左孩子 
		} 
		else 
		{
			p->rchild = s; //插入s为右孩子 
		} 
		return TURE; 
	}
	else
	{
		return FALSE; //树中已有关键字相同的结点,不再插入 
	}
 } 

三、删除

cpp 复制代码
Status DeleteBST(BiTree *T,int key)
{
	if(!*T)
	{
		return FALSE;
	}
	else
	{
		if(key == (*T)->data)
		{
			return Delete(T);
		}
		else if(key < (*T)->data)
		{
			return DeleteBST(&(*T)->lchild,key);
		}
		else if(key > (*T)->data)
		{
			return DeleteBST(&(*T)->rchild,key);
		}
	}
 } 

Status Delete(BiTree *p)
{
	BiTree q,s;
	if((*p)->rchild == NULL)
	{
		p = *p;
		*p = (*p)->lchild;
		free(q);
	}
	else if((*p)->lchild == NULL)
	{
		q = *p;
		*p = (*p)->rchild;
		free(q);
	}
	else
	{
		q = *p;
		s = (*p)->lchild;
		while(s->rchild)
		{
			q = s;
			s = s->rchild;
		}
		(*p)->data = s->data;
		if(q  != p)
		{
			q->rchild = s->lchild;
		}
		else
		{
			q->lchild = s->lchild;
		}
		free(s);
	}
	return tree;
}
相关推荐
星空露珠几秒前
迷你世界脚本文字板接口:Graphics
数据结构·游戏·lua
_星辰大海乀41 分钟前
LinkedList 双向链表
java·数据结构·链表·list·idea
星空露珠2 小时前
迷你世界脚本显示板管理接口:DisPlayBoard
数据结构·游戏·lua
商bol452 小时前
算阶,jdk和idea的安装
数据结构·c++·算法
柠檬鲨_5 小时前
C语言100天练习题【记录本】
c语言·数据结构·算法
星空露珠12 小时前
迷你世界脚本聊天接口:Chat
数据结构·游戏·lua
啥都想学的又啥都不会的研究生12 小时前
Redis设计与实现-数据结构
数据结构·数据库·redis·笔记·缓存·性能优化·skiplist
mit6.82412 小时前
[Lc(2)滑动窗口_1] 长度最小的数组 | 无重复字符的最长子串 | 最大连续1的个数 III | 将 x 减到 0 的最小操作数
数据结构·c++·算法·leetcode
zjoy_223312 小时前
【数据结构】什么是栈||栈的经典应用||分治递归||斐波那契问题和归并算法||递归实现||顺序栈和链栈的区分
java·c语言·开发语言·数据结构·c++·算法·排序算法
油泼辣子多加14 小时前
【华为OD机考】华为OD笔试真题解析(20)--投篮大赛
数据结构·算法·华为od