排序二叉树二叉排序树的操作
排序二叉树 时间:2021-09-12 阅读:(
)
二叉排序树的构造和查找方法
二叉排序树的构造过程:按照给定序列,以此将结点插入二叉排序树中,在二叉排序树中插入新结点,要保证插入后的二叉树仍符合二叉排序树的定义。
插入过程:若二叉排序树为空,则待插入结点*S作为根结点插入到空树中;
当非空时,将待插结点关键字S->key和树根关键字t->key进行比较,
若s->key = t->key,则无须插入,若s->key< t->key,则插入到根的左子树中,
若s->key> t->key,则插入到根的右子树中。
而子树中的插入过程和在树中的插入过程相同,
如此进行下去,直到把结点*s作为一个新的树叶插入到二叉排序树中,或者直到发现树已有相同关键字的结点为止。
说明:
① 每次插入的新结点都是二叉排序树上新的叶子结点。
② 由不同顺序的关键字序列,会得到不同二叉排序树。
③ 对于一个任意的关键字序列构造一棵二叉排序树,其实质上对关键字进行排序。
查找的过程类似,从根结点开始进行比较,小于根结点的在左子树上,大于根结点的在右子树上,以此查找下去,直到查找成功或不成功(比较到叶子结点)。
100。120。110。130。80。60。90。构造二叉排序树
构造二叉排序树时遵照定义即可:
(1)若左子树不空,则左子树上所有结点的值均小于它的根结点的值;
(2)若右子树不空,则右子树上所有结点的值均大于它的根结点的值;
(3)左、右子树也分别为二叉排序树;
则该树应为
100
╱ ╲
80 120
╱ ╲ ╱ ╲
60 90 110 130二叉排序树
二叉排序树 目录[隐藏]
二叉排序树
二叉排序树的查找
二叉排序树的插入和删除
插入算法
[编辑本段]二叉排序树
二叉排序树(Binary Sort Tree)又称二叉查找树。
它或者是一棵空树;或者是具有下列性质的二叉树: (1)若左子树不空,则左子树上所有结点的值均小于它的根结点的值; (2)若右子树不空,则右子树上所有结点的值均大于它的根结点的值; (3)左、右子树也分别为二叉排序树;
[编辑本段]二叉排序树的查找
步骤:若根结点的关键字值等于查找的关键字,成功。
否则,若小于根结点的关键字值,递归查左子树。
若大于根结点的关键字值,递归查右子树。
若子树为空,查找不成功。
[编辑本段]二叉排序树的插入和删除
与次优二叉树相对,二叉排序树是一种动态树表。
其特点是:树的结构通常不是一次生成的,而是在查找过程中,当树中不存在关键字等于给定值的节点时再进行插入。
新插入的结点一定是一个新添加的叶子节点,并且是查找不成功时查找路径上访问的最后一个结点的左孩子或右孩子结点。
[编辑本段]插入算法
首先执行查找算法,找出被插结点的父亲结点。
判断被插结点是其父亲结点的左、右儿子。
将被插结点作为叶子结点插入。
若二叉树为空。
则首先单独生成根结点。
注意:新插入的结点总是叶子结点。
//在二叉排序树中插入查找关键字key void InsertBST(t,key) { if(t==NULL) { t=new BiTree; t->lchild=t->rchild=NULL; t->data=key; return; } if(key<t->data ) InsertBST(t->lchild,key); else InsertBST (t->rchild, key ); } //n个数据在数组d中,tree为二叉排序树根 void CreateBiTree(tree,d[ ],n) { tree=NULL; for(i=0;i<n;i++) InsertBST(tree,d); } 最小值二叉树c例程: #include<stdio.h> struct priorityqueue { int capacity; int size; int *elements; }*tryit; struct priorityqueue *initialize ( int maxelements ) { struct priorityqueue *h; h = malloc ( sizeof ( struct priorityqueue ) ); h -> elements = malloc ( sizeof ( int ) * ( maxelements + 1 ) ); h -> capacity = maxelements; h -> size = 0; h -> elements[0] = -23767; return h; } void insert ( int x , struct priorityqueue *h ) { int i; for ( i = ++h -> size ; h -> elements[ i / 2 ] > x ; i /= 2 ) h -> elements[ i ] = h -> elements[ i / 2 ]; h -> elements [ i ] = x; } int deletemin ( struct priorityqueue *h ) { int i , child ; int minelement , lastelement; minelement = h -> elements[ 1 ]; lastelement = h -> elements[ h -> size-- ]; for ( i = 1 ; i * 2 <= h -> size ; i = child ) { child = i * 2; if ( child != h -> size && h -> elements[ child + 1 ] < h -> elements[ child ] ) child++; if ( lastelement > h -> elements[ child ] ) h -> elements[ i ] = h -> elements[ child ]; else break; } h -> elements[ i ] = lastelement; return minelement; } main() { tryit = initialize ( 10 ); insert ( 4 , tryit ); insert ( 5 , tryit ); insert ( 10 , tryit ); insert ( 3 , tryit ); printf ( "%d
" , deletemin ( tryit ) ); printf ( "%d
" , deletemin ( tryit ) ); printf ( "%d
" , deletemin ( tryit ) ); printf ( "%d
" , deletemin ( tryit ) ); getch(); }二叉排序树的操作
实验目的】
由读入数据构造二叉排序树,并进行插入,查找,删除操作。
【设计原理】
二叉排序树:或者是一棵空树,或者是具有下列性质的二叉树:
1. 若它的左子树不空,则右子树上所有结点的值均大于它的根结点的值
2. 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值
3. 它的左,右子树也分别为二叉排序树
【算法描述】
查找:以二叉链表为存储结构,二叉排序树不空时,首先将给定值和根结点的关键字比较,若相等,则查找成功,否则按大小关系,分别在左,右子树上继续查找。
插入:在查找过程中,当树中不存在关键字等于定值的结点时再进行插入。
插入的是在叶子结点。
删除:1.若待删结点为叶子结点,即删去该结点。
2.若待删结点只有左或右子树,即将该子树直接连到待删结点的双亲的对应子树。
4. .若待删结点左右子树都不空,则将它中序遍历的直接前驱替代它,再删去这个前驱结点。
【程序清单】
#include <stdio.h>
#include <conio.h>
#define NULL 0
#define MAX 20
struct node
{int data;
struct node *r,*l;
}*head,*inord[MAX];
int count=0;
int n=0;
myprint(int x,int y,char *s,int tc,int bc)
{
gotoxy(x,y);
textcolor(tc);
textbackground(bc);
cprintf(s);
这个月11号ShockHosting发了个新上日本东京机房的邮件,并且表示其他机房可以申请转移到日本,刚好赵容手里有个美国的也没数据就发工单申请新开了一个,这里做个简单的测试,方便大家参考。ShockHosting成立于2013年,目前提供的VPS主机可以选择11个数据中心,包括美国洛杉矶、芝加哥、达拉斯、杰克逊维尔、新泽西、澳大利亚、新加坡、日本、荷兰和英国等。官方网站:https://shoc...
UCloud优刻得近日针对全球大促活动进行了一次改版,这次改版更加优惠了,要比之前的优惠价格还要低一些,并且新增了1核心1G内存的快杰云服务器,2元/首年,47元/年,这个价格应该是目前市面上最低最便宜的云服务器产品了,有需要国内外便宜VPS云服务器的朋友可以关注一下。UCloud好不好,UCloud服务器怎么样?UCloud服务器值不值得购买UCloud是优刻得科技股份有限公司旗下拥有的云计算服...
pia云怎么样?pia云是一家2018的开办的国人商家,原名叫哔哔云,目前整合到了魔方云平台上,商家主要销售VPS服务,采用KVM虚拟架构 ,机房有美国洛杉矶、中国香港和深圳地区,洛杉矶为crea机房,三网回程CN2 GIA,带20G防御。目前,Pia云优惠促销,年付全场8折起,香港超极速CN2季付活动,4核4G15M云服务器仅240元/季起,香港CN2、美国三网CN2深圳BGP优质云服务器超高性...
排序二叉树为你推荐
云知声厦门云知芯智能科技有限公司怎么样?项目质量管理在项目质量管理中有什么项目质量管理简述项目质量管理保证和项目质量控制的内容和两者区别与联系,我正在考试求大神救命小项目想创业,二十万以内有什么好项目?jsp源码帮忙编个JSP代码网络限速软件谁有网络限速的软件,路由器。很卡~别人一看电影什么都干不了。提供个限速的软件。下载成功给分!黑屏操作麻烦问一下 黑屏的各个指令分销渠道案例海尔公司的分销渠道是?超市商品价格超市商品价格写一篇小作文怎么写申请信箱怎么申请邮箱啊
东莞服务器租用 com域名抢注 pw域名 外国域名 lighttpd 申请空间 网盘申请 免空 135邮箱 免费活动 qq云端 Updog drupal安装 韩国代理ip 可外链的相册 如何登陆阿里云邮箱 万网服务器 nnt 酷锐 第八届中美互联网论坛 更多