当前位置: 首页 > 编程日记 > 正文

二叉排序树的相关操作

#include <IOSTREAM.H>
#include <STDLIB.H>
//二叉树的生成和释放
typedef struct Node
{int data;struct Node * pParent;struct Node * pLeftChild;struct Node * pRightChild;
}Node;Node * Create_BTree(int *array,Node* pParent=NULL)//二叉排序树的创建,按照先序遍历的方法进行构造
{static int i=0;if (array[i]==0){return NULL;}Node *temp=(Node *)malloc(sizeof(Node));temp->data=array[i];temp->pParent=pParent;i++;temp->pLeftChild=Create_BTree(array,temp);i++;temp->pRightChild=Create_BTree(array,temp);return temp;
}
void Mid_Order(Node* tree)//二叉排序树的中序遍历
{if (tree==NULL){return;}Mid_Order(tree->pLeftChild);cout<<tree->data<<" ";Mid_Order(tree->pRightChild);
}
void Destroy_BTree(Node* tree)//二叉排序树的是否
{if (tree==NULL){return;}Destroy_BTree(tree->pLeftChild);Destroy_BTree(tree->pRightChild);free(tree);
}
Node* Tree_Search(Node* tree,int x)//二叉排序树的查找
{Node* temp=tree;while(temp){if(temp->data==x)break;else if(temp->data>x)temp=temp->pLeftChild;elsetemp=temp->pRightChild;}return temp;
}
Node * Tree_Minimum(Node* tree)//二叉排序树的最小节点
{while(tree&&tree->pLeftChild){tree=tree->pLeftChild;}return tree;
}
Node * Tree_Maximum(Node* tree)//二叉排序树的最大节点
{while(tree&&tree->pRightChild){tree=tree->pRightChild;}return tree;
}
Node * Tree_Successor(Node *p)//返回节点p的后继//中序遍历
{if(p==NULL)return p;else if(p->pRightChild)return Tree_Minimum(p->pRightChild);else{while(p->pParent&&p->pParent->pRightChild==p)p=p->pParent;return p->pParent;}}
Node *Tree_PreDecessor(Node* p)//中序遍历 求p的前驱节点
{if (p==NULL)return p;else if(p->pLeftChild)return Tree_Maximum(p->pLeftChild);else{while(p->pParent&&p->pParent->pLeftChild==p)p=p->pParent;return p->pParent;}
}
void  Tree_Insert(Node* &tree,int x)//给二叉排序树插入新节点
{Node * pNodeNew=(Node*)malloc(sizeof(Node));pNodeNew->pLeftChild=NULL;pNodeNew->pRightChild=NULL;pNodeNew->data=x;if(tree==NULL){pNodeNew->pParent=NULL;tree=pNodeNew;return;}Node * pTempParent=NULL,*pTemp=tree;while(pTemp){pTempParent=pTemp;if (pTemp->data<x){pTemp=pTemp->pRightChild;} else{pTemp=pTemp->pLeftChild;}}pNodeNew->pParent=pTempParent;if (pTempParent->data<x){pTempParent->pRightChild=pNodeNew;}elsepTempParent->pLeftChild=pNodeNew;
}
void Tree_Delete(Node* &tree,Node *p)//删除二叉排序树中一个节点
{if(p->pLeftChild==NULL&&p->pRightChild==NULL)//删除叶节点
    {Node *pParent=p->pParent;if (pParent){if (pParent->data<p->data){pParent->pRightChild=NULL;}elsepParent->pLeftChild=NULL;free(p);} else{tree=NULL;free(p);}}else if (p->pLeftChild&&p->pRightChild==NULL||p->pRightChild&&p->pLeftChild==NULL)//只有一个子树
    {Node *pParent=p->pParent;if (pParent){if (pParent->data<p->data)//子树连到父节点的右孩子
            {if(p->pLeftChild)//哪个子树不为空连哪个
                {pParent->pRightChild=p->pLeftChild;p->pLeftChild->pParent=pParent;}else{pParent->pRightChild=p->pRightChild;p->pRightChild->pParent=pParent;}free(p);}else{if(p->pLeftChild)//哪个子树不为空连哪个
                {pParent->pLeftChild=p->pLeftChild;p->pLeftChild->pParent=pParent;}else{pParent->pLeftChild=p->pRightChild;p->pRightChild->pParent=pParent;}free(p);    }} else{if(p->pLeftChild){p->pLeftChild->pParent=NULL;tree=p->pLeftChild;}else{p->pRightChild->pParent=NULL;tree=p->pRightChild;}free(p);}}else//有两个子树
    {Node *temp=Tree_Maximum(p->pLeftChild);int x=p->data;p->data=temp->data;temp->data=x;Tree_Delete(tree,temp);}
}
void main()
{int array[]={15,6,3,2,0,0,4,0,0,7,0,13,9,0,0,0,18,17,0,0,20,0,0};Node *tree=Create_BTree(array);Tree_Insert(tree,21);Mid_Order(tree);cout<<endl;Node *temp=Tree_Search(tree,7);//查找
    Tree_Delete(tree,temp);Mid_Order(tree);cout<<endl;Destroy_BTree(tree);
}

转载于:https://www.cnblogs.com/GoAhead/archive/2012/10/26/2741508.html

相关文章:

IDEA的常用操作(快捷键)

Alt回车 导入包,自动修正 CtrlN 查找类 CtrlShiftN 查找文件 CtrlAltL 格式化代码 CtrlAltO 优化导入的类和包 AltInsert 生成代码(如get,set方法,构造函数等) CtrlE或者AltShiftC 最近更改的代码 CtrlR 替换文本 CtrlF 查找文本 CtrlShiftSpace 自动补全代码 Ctrl空格 代码提示…

UI设计培训分享:ui的字体怎么正确设置?

UI设计工作中&#xff0c;UI字体设计是非常重要且频繁使用的一个工作内容之一&#xff0c;对于字体的设计也是非常需要进行注意的&#xff0c;本期小编为大家介绍的UI设计培训内容就是关于ui的字体怎么正确设置?来看看下面详细介绍。 UI设计培训分享&#xff1a;ui的字体怎么正…

【译文转帖】用C#写COM组件 Building COM Objects in C#

说明: 我是一个C#程序员,但是有一次一个需求只能用C/C去写,恰好需要读取的数据存放在DB(SQL CE v3)里面,而我又不会C/C(关键是用OleDB访问DB,这个实在是繁琐),所以催生了用C#写一个COM组件,用C/C去调用的想法.可谓,很傻很天真.但是也是一种思路,如果MS提供C API的话,问题就简单…

apache 开启 gzip 压缩服务

2019独角兽企业重金招聘Python工程师标准>>> 1、打开 apache 的 "httpd.conf" 文件&#xff0c;找到以下这一行&#xff0c;将它前面的注释&#xff08;#&#xff09;去掉&#xff1a; LoadModule deflate_module modules/mod_deflate.so 2、在 httpd.con…

Scratch等级考试(二级)模拟题

青少年编程竞赛交流群已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 微信后台回复“资料下载”可获取以往学习的材料&#xff08;视频、代码、文档&…

找Java培训机构有哪些评判标准

想要学习java技术&#xff0c;找java培训机构是大多数人的选择&#xff0c;目前市面上的java培训机构有很多&#xff0c;用什么评判标准来找到时候自己的机构呢?来看看下面小编为大家介绍的找Java培训机构有哪些评判标准? 找Java培训机构有哪些评判标准? 1.师资力量的标准 我…

Josephus问题

目的&#xff1a;练习下单链表和指针 &#xff08;OS 10.7 Xcode 4.2&#xff09; 代码如下&#xff1a; 1 #include <stdio.h>2 #include <stdlib.h>3 4 typedef struct lnode5 {6 int data;7 struct lnode *next; 8 }lnode;9 10 int main(void) 11 …

Datawhale组队学习周报(第017周)

本周&#xff08;05月31日~06月06日&#xff09;&#xff0c;第 25 期组队学习一共有 3 门开源课程&#xff0c;共组建了 3 个学习群&#xff0c;参与的学习者有 292 人&#xff0c;其中 web开发入门教程 已经结营&#xff0c;另外两门课程也在结营筹划中。 第 26 期组队学习也…

给一个ul列表中点击到的li赋予样式

2019独角兽企业重金招聘Python工程师标准>>> 效果如下&#xff0c;点那个那个获取样式,之前已经有样式的取消。 代码如下&#xff0c;我是在菜鸟教程上在线编辑的&#xff0c;所以就这样喽~ if判断不加也行 <!DOCTYPE html> <html> <head> ​ <…

参加过java培训机构的学员如何找出路

java技术在互联网行业的发展&#xff0c;引起了越来越多人的关注&#xff0c;市面上的java培训机构也不计其数&#xff0c;很多人都比较想知道参加过java培训机构的学员如何找出路?对于这个问题&#xff0c;我们来看看下面的详细介绍就知道了。 参加过java培训机构的学员如何找…

pku The Windy's KM最小权匹配 or 最小费用最大流

http://poj.org/problem?id3686 题意&#xff1a; 给定n个玩具&#xff0c;有m个车间&#xff0c;给出每个玩具在每个车间的加工所需的时间mat[i][j]表示第i个玩具在第j个车间加工所需的时间&#xff0c;规顶只有第i个玩具在j车间完成时第j车间才能接受其他玩具来生产。求加工…

react按需加载(getComponent优美写法),并指定输出模块名称解决缓存(getComponent与chunkFilename)...

react配合webpack进行按需加载的方法很简单&#xff0c;Route的component改为getComponent&#xff0c;组件用require.ensure的方式获取&#xff0c;并在webpack中配置chunkFilename。const chooseProducts (location, cb) > { require.ensure([], require > { cb(null,…

【青少年编程】【二级】绘制方形螺旋

「青少年编程竞赛交流群」已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 微信后台回复“资料下载”可获取以往学习的材料&#xff08;视频、代码、文档&…

软件测试的发展空间大吗

软件测试的发展空间大吗?很多人都非常关心这个问题&#xff0c;软件测试在互联网行业的发展空间是非常大的&#xff0c;学习软件测试技术并不难&#xff0c;只要经过系统的软件测试培训都是可以学会的&#xff0c;下面来看看详细的介绍。 软件测试的发展空间大吗 早期&#xf…

vim windows linux文件格式转换

vim windows linux文件格式转换 set ff? #显示当前文件格式set ffunix #设置成unix格式set ffdos #设置成dos格式posted on 2012-11-02 09:43 一颗卤蛋 阅读(...) 评论(...) 编辑 收藏 转载于:https://www.cnblogs.com/lyroge/archive/2012/11/02/2750689.html

NCEPU:线下组队学习周报(009)

线下组队学习 经过一段时间的准备&#xff0c;我们组织的线下组队学习逐步进入正轨。欢迎华北电力大学保定校区的伙伴加入进来大家一起学习一起成长。 我们开展组队学习的内容为&#xff1a; &#xff08;1&#xff09;周志华的《机器学习》&#xff08;西瓜书&#xff09; …

零基础学java培训怎么选择学校

java技术在互联网行业的快速发展&#xff0c;引起了很多人的关注&#xff0c;大家都想通过学习java技术来加入到这个行业&#xff0c;那么零基础学java培训怎么选择学校呢?如今市面上的java培训机构这么多&#xff0c;下面小编就来为大家详细的介绍一下吧。 零基础学java培训怎…

C++对象的内存布局1---基础篇----C++ 虚函数表解析

[-] 前言虚函数表一般继承&#xff08;无虚函数覆盖&#xff09;一般继承&#xff08;有虚函数覆盖&#xff09;多重继承&#xff08;无虚函数覆盖&#xff09;多重继承&#xff08;有虚函数覆盖&#xff09;安全性结束语附录一&#xff1a;VC中查看虚函数表附录 二&#xff1a…

iOS开发 关于启动页和停留时间的设置

引言: 在开发一款商业App时&#xff0c;我们大都会为我们的App设置一个启动页。 苹果官方对于iOS启动页的设计说明&#xff1a; 为了增强应用程序启动时的用户体验&#xff0c;您应该提供一个启动图像。启动图像与应用程序的首屏幕看起来非常相似。 当用户在主屏幕上点击您的应…

web前端培训:CSS中单行文本溢出显示省略号的方法

CSS中单行文本溢出显示省略号的方法你知道吗?在web前端技术学习中&#xff0c;这个问题其实是属于老生常谈了&#xff0c;因为css单行文本的应用是非常频繁的&#xff0c;比如网站最基本的文章列表&#xff0c;标题会很长&#xff0c;而显示列表的区域宽度却没有这么宽&#x…

如何使用pyecharts中自带的数据集?

如何使用 pyecharts 中自带的数据集&#xff1f; 我们在学习pyehcarts绘图的过程中&#xff0c;需要一些练习的数据。 pyecharts为我们提供了这样的数据集 – Faker&#xff0c;存储于 faker.py 文件中。 下面&#xff0c;我们就来详细介绍一下。 1. Faker中包含的数据集 …

Ext.app.controller的refs

简 单来说&#xff0c;就是4.0建议的MVC中controller引用组件的一种方式&#xff0c;selector中设置组件&#xff0c;可以用id、classname&#xff0c;但推荐用 ComponentQuery&#xff08;“组件检索”功能&#xff0c;这个也是4.0的新特性&#xff09;来定位组件。ref中设置引…

MBA 工商管理课程-风险型决策方法

&#xff08;二&#xff09;风险型决策方法 适用的条件 未来情况不止一种&#xff0c;管理者不知道到底哪种情况会发生&#xff0c;但知道每种情况发生的概率 常用方法&#xff1a; 决策树法&#xff1a;用树状图来描述各种方案在…

Python培训分享:python如何用cookie实现自动模拟登录?

本期教程Python培训教程为大家带来的是python如何用cookie实现自动模拟登录?据小编的了解&#xff0c;python实现cookie自动登录&#xff0c;目前来说有许多第三方库都可以直接使用&#xff0c;这里以常用的requests库为例简单介绍一下&#xff0c;整个过程非常简单&#xff0…

如何使用pyecharts中的主题样式?

如何使用pyecharts中的主题样式&#xff1f; pyechart为用户提供了一套使用方便的主题风格。 本篇图文将总结pyecharts.globals中ThemeType所有主题风格并进行详细的解释。 class _ThemeType:BUILTIN_THEMES ["light", "dark", "white"]LIGH…

乐意使人恐惧,源于自身的空虚

有一回我对稻草人说&#xff1a;“你总是孤独守望在这片寂寞的土地上&#xff0c;你一定厌倦了吧&#xff1f;” 稻草人回答道&#xff1a;“能使他人恐惧是一种深沉持久的快乐&#xff0c;对此我永远不会感到厌倦。” 我低头沉思&#xff0c;尔后说道&#xff1a;“的确如此&a…

Maven学习(一) - Maven基础

2019独角兽企业重金招聘Python工程师标准>>> Maven作为Java语言的构建和依赖管理工具&#xff0c;已经被广泛使用。但对于maven的pom.xml的配置以及插件的使用&#xff0c;大部分人也仅仅限于了解的程度。工欲善其事&#xff0c;必先利其器。在拖延了很久后&#xf…

Python培训就业方向有哪些

关注“Python培训就业方向有哪些”的同学&#xff0c;基本都是打算学习Python技术但是对于Python的就业还是很迷茫的&#xff0c;针对在这个问题&#xff0c;小编下面为大家做下简单的解析&#xff0c;希望能够帮助到大家。 Python培训就业方向有哪些? 1.Python自动化测试 熟悉…

linux下安装hadoop

关键词&#xff1a;Ubuntu;hadoop; 注意&#xff1a;开始这一步之前&#xff0c;需安装Oracle的jdk&#xff0c;参见&#xff1a; http://www.cnblogs.com/fengfengqingqingyangyang/archive/2012/11/06/2756981.html 1、下载hadoop的合适版本&#xff1a;http://labs.mop.com/…

谢文睿:西瓜书 + 南瓜书 吃瓜系列 5. 决策树

Datawhale南瓜书是经典机器学习教材《机器学习》&#xff08;西瓜书&#xff09;的公式推导解析指南&#xff0c;旨在让在学习西瓜书的过程中&#xff0c;再也没有难推的公式&#xff0c;学好机器学习。 以往内容&#xff1a; 西瓜书公式推导讲解来了&#xff01;0. 导学1. 一…